「模拟赛20180307」三元组 exclaim 枚举+树状数组

题目描述

给定 n,k ,求有多少个三元组 (a,b,c) 满足 1abcna+b2c3 (mod k)

输入

多组数据,第一行数据组数T
每组数据两个整数,nk

输出

T行,每行一个整数,表示满足条件的三元组的个数。

样例

样例输入

1
10 7

样例输出

27
//为什么老被和谐啊

数据范围

1n,k105
T400
时间限制4s

题解

与其他学校互测,然后做题感觉很不友好……
这道题数据很有特点(哪里很有特点了),105显然是一个象征性的数字,它意味着O(n log n)是可以过的(这么大的T被无视了啊)。
那么很自然的想到,这个式子并没有什么规律(我也很无奈啊),我们可以考虑枚举a,b,c中的1个。
但是我们选择哪一个比较好呢?容易想到,应该是c,它的次数最高,不易计算。

接下来考虑一个简化的问题,如果不取余k,该怎么办?
对于一个数b,由于1ab,显然c3只有在[b2+1,b2+b]范围内才有解,而且是唯一解。
所以每一个b可以为在[b2+1,b2+b]c3提供一个解,这不就是区间增加一个值吗?树状数组即可做到。

再考虑取余k时,发现情况如出一辙,一样的做就可以了。唯一一个问题就是,[b2+1,b2+b]可能长度超过了k
这时能发现长度超过k后完全覆盖了所有区域,任何一个c都可以使用这个b,我们只需要一个计数器count,每次增加bk

现在,这道题的解法就呼之欲出了。我们从小到大枚举c,先在树状数组(tree)[c2+1,c2+c]的区间加上1,并更新count,答案就等于tree[c3%k]+count。时间复杂度为O(Tn log n)(再说一次请无视T的大小)

Code:

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define N 100005
#define ll long long
int T, n, mod;
ll ans, now, t[N];
void update(int x, int v)
{
    for (int i = x; i <= mod; i += i & -i)
        t[i] += v;
}
ll getsum(int x)
{
    ll ans = 0;
    for (int i = x; i; i -= i & -i)
        ans += t[i];
    return ans;
}
int main()
{
    freopen("exclaim.in", "r", stdin);
    freopen("exclaim.out", "w", stdout);
    scanf("%d", &T);
    for (int cas = 1; cas <= T; cas++)
    {
        scanf("%d%d", &n, &mod);
        ans = now = 0;
        memset(t, 0, sizeof(t));
        for (int i = 1; i <= n; i++)
        {
            int l =(1ll * i * i + 1)% mod + 1, r =(1ll * i * i + i)% mod + 1;
            if (l <= r)
                update(l, 1), update(r + 1, -1);
            else
                update(1, 1), update(r + 1, -1), update(l, 1);
            int c = 1ll * i * i % mod * i % mod;
            now +=(i - 1)/ mod;
            ans += getsum(c + 1) + now;
        }
        printf("Case %d: ", cas);
        cout << ans;
        putchar(10);
    }
}

最后的吐槽:exclaim并不是三元组的意思,是惊叫的意思……至于为什么,我也不知道……

posted @   ModestStarlight  阅读(2788)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示