[HG]AK 题解
前言
什么鬼畜玩意,扶我起来,我要用__int128,这辈子都不珂能用龟速乘的...
真香。
题解
我们知道这个模数是个神奇的东西
\(2305843008676823040 = 2^{29} \times 3 \times 5 \times 17 \times 65537\)
所以\(\varphi(2305843008676823040) = 2^{28} \times 2 \times 2^2 \times 2^4 \times 2^{16} = 2^{51}\)
\(a^{\varphi(n)}=1\ (mod\ n)\),所以在\(60\)次以内,该数\(mod 2305843008676823040\)一定会变为\(1\)。
用线段树维护序列,再加一个龟速乘,解决问题
#include <cstdio>
#define ll long long
const ll MOD = 2305843008676823040ll;
ll s[1000001];
bool flg[1000001];
long long read(){
long long x = 0; int zf = 1; char ch = ' ';
while (ch != '-' && (ch < '0' || ch > '9')) ch = getchar();
if (ch == '-') zf = -1, ch = getchar();
while (ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar(); return x * zf;
}
inline ll mul(ll x, ll y){
ll res = 0;
for ( ; y; y >>= 1ll, (x <<= 1ll) %= MOD)
if(y & 1)
(res += x) %= MOD;
return res;
}
void build(int pos, int l, int r){
if (l == r){
s[pos] = read();
flg[pos] = ((s[pos] == 1 || !s[pos]) ? 1 : 0);
return ;
}
int mid = (l + r) >> 1;
build(pos << 1, l, mid);
build(pos << 1 | 1, mid + 1, r);
flg[pos] = flg[pos << 1] & flg[pos << 1 | 1];
s[pos] = (s[pos << 1] + s[pos << 1 | 1]) % MOD;
}
ll query(int pos, int l, int r, int x, int y){
if (x <= l && r <= y && flg[pos])
return s[pos];
if (l == r){
ll res = s[pos];
ll tmp = mul(s[pos], s[pos]);
if (tmp == s[pos])
flg[pos] = 1;
s[pos] = tmp;
return res;
}
int mid = (l + r) >> 1;
ll res;
if (y <= mid)
res = query(pos << 1, l, mid, x, y);
else if (x > mid)
res = query(pos << 1 | 1, mid + 1, r, x, y);
else{
res = query(pos << 1, l, mid, x, y);
(res += query(pos << 1 | 1, mid + 1, r, x, y)) %= MOD;
}
s[pos] = (s[pos << 1] + s[pos << 1 | 1]) % MOD;
flg[pos] = flg[pos << 1] & flg[pos << 1 | 1];
return res
}
int main(){
int n = read(), m = read();
for (register int i = 1; i <= 1000000; ++i) flg[i] = 1;
build(1, 1, n);
while (m--){
int l = read(), r = read();
ll res = query(1, 1, n, l, r) % MOD;
printf("%lld\n", res);
}
return 0;
}
[HG]AK 题解的更多相关文章
- [HG]Market 题解
题目描述 在比特镇一共有 \(n\) 家商店,编号依次为 \(1\) 到 \(n\). 每家商店只会卖一种物品,其中第 \(i\) 家商店的物品单价为 \(c_i\),价值为 \(v_i\),且该商店 ...
- [HG]walk 题解
前言 学长博客划水,抄题解,差评. 于是我来重新写一篇正常的题解,虽然解法跟标程不一样,但是复杂度是一样的. 题面 题目描述 在比特镇一共有\(n\)个街区,编号依次为\(1\)到\(n\),它们之间 ...
- URAL 2047 Maths 打表 递推
MathsTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view.action? ...
- 「kuangbin带你飞」专题十九 矩阵
layout: post title: 「kuangbin带你飞」专题十九 矩阵 author: "luowentaoaa" catalog: true tags: mathjax ...
- [HG]子树问题 题解
前言 模拟赛赛时SubtaskR3没开long long丢了20分. 题意简述 题目描述 对于一棵有根树(设其节点数为 \(n\) ,则节点编号从 \(1\) 至 \(n\) ),如果它满足所有非根节 ...
- 【题解】小X的AK计划
题目描述 虽然在小X的家乡,有机房一条街,街上有很多机房.每个机房里都有一万个人在切题.小X刚刷完CodeChef,准备出来逛逛.机房一条街有n个机房,第i个机房的坐标为xi,小X的家坐标为0.小X在 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- [HG]走夜路 题解
前言 整个机房就我一个人在想动态规划. 想了半天发现一堆性质,结果由于DP中出现折线挂了. 题目描述 某NOIP普及组原题加强版. \(Jim\) 非常怕黑,他有一个手电筒,设手电筒的电量上限为 \( ...
- [HG]腿部挂件 题解
前言 暴力跑的比正解快. 以下暴力(循环展开+fread读入输出优化) #include<cstdio> #pragma GCC optimize(3, "Ofast" ...
随机推荐
- is_enabled()检查元素是否可以编辑 如文本框
演示代码from selenium import webdriverdriver = webdriver.Firefox()driver.get("https://www.baidu.com ...
- Mac搭建github Page的Hexo免费个人博客
1.基础准备 github账号 安装git 安装node.js.npm 2.创建repo 3.配置SSH key 这一步并不重要,配置SSH key与否,并不影响博客的搭建和使用,只是配置了之后,更新 ...
- 爬虫二之Requests
requests 实例引入 import requests response = requests.get('https://www.baidu.com') response.status_code ...
- 使用cython库对python代码进行动态编译达到加速效果及python第三方包的制作安装
1.测试代码:新建 fib.pyx # coding:utf-8 import matplotlib.pyplot as plt import numpy as np from sklearn.cl ...
- bits,Bytes,KB,MB,GB和TB之间的换算关系
1Bytes=8bits(1字节等于8位) 1KB=1024Bytes(1KB等于1024字节) 1MB=1024KB 1GB=1024MB 1TB=1024GB 为啥带宽100M而下载大概只是12. ...
- java面向对象详细全面介绍
一.面向对象 1.面向过程与面向对象 POP与OOP都是一种思想,面向对象是相对于面向过程而言的.面向过程,强调的是功能行为,以函数为最小单位,考虑怎么做.面向对象,将功能封装进对象,强调具备了功能的 ...
- P1622释放囚犯
这是一道绿题,是一道让人想用贪心但却是区间DP的题目,难倒了我这个蒟蒻. 这个题其实仔细观察是类似于石子合并的!合并石子的代价便是肉的数量,求最小代价.所以我们设dp[i][j]为释放第i个到第j个所 ...
- [CQOI2012]模拟工厂 题解(搜索+贪心)
[CQOI2012]模拟工厂 题解(搜索+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327574 链接题目地址:洛谷P3161 BZOJ P26 ...
- 搜索 问题 D: 神奇密码锁
这道题个人认为隐含着状态转换,所以想到的还是BFS,将其中一位数加一或减一或交换临近两位,进入下一状态,使用一个大小为10000的bool数组判重,由于BFS的特性,得到的一定是最小步数: 普通BFS ...
- 简单的物流项目实战,WPF的MVVM设计模式(三)
往Services文件里面添加接口以及实现接口 IUserService接口 List<User> GetAllUser(); GetUserService类 ConnectToDatab ...