The 2019 Asia Nanchang First Round Online Programming Contest The Nth Item
The Nth Item
思路:
先用特征根法求出通向公式,然后通向公式中出现了\(\sqrt{17}\),这个可以用二次剩余求出来,然后可以O(\(log(n)\))求出。
但是还不够,我们先对\(n\)欧拉降幂,然后求base为\(\sqrt{1e9}\)的快速幂,预处理一些东西,就可以类似O(1)求出了。
代码:
#pragma GCC optimize(2)
#pragma GCC optimize(3)
#pragma GCC optimize(4)
#include<bits/stdc++.h>
using namespace std;
#define y1 y11
#define fi first
#define se second
#define pi acos(-1.0)
#define LL long long
//#define mp make_pair
#define pb push_back
#define ls rt<<1, l, m
#define rs rt<<1|1, m+1, r
#define ULL unsigned LL
#define pll pair<LL, LL>
#define pli pair<LL, int>
#define pii pair<int, int>
#define piii pair<pii, int>
#define pdd pair<double, double>
#define mem(a, b) memset(a, b, sizeof(a))
#define debug(x) cerr << #x << " = " << x << "\n";
#define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
//head
const int MOD = 998244353;
const LL fsqrt17 = 473844410;
const LL sqrt17 = MOD-fsqrt17;
const LL inv2 = (MOD+1)/2;
const LL invsqrt17 = 438914993;
const int N = 4e4 + 5;
LL p[N], pp[N], P[N], PP[N], q, n;
LL f(LL n) {
    return (p[n%(N-1)]*P[n/(N-1)])%MOD;
}
LL F(LL n) {
    return (pp[n%(N-1)]*PP[n/(N-1)])%MOD;
}
int main() {
    p[0] = pp[0] = 1;
    for (int i = 1; i < N; ++i) p[i] = p[i-1]*(3+sqrt17)%MOD*inv2%MOD, pp[i] = pp[i-1]*(3+fsqrt17)%MOD*inv2%MOD;
    P[0] = PP[0] = 1;
    for (int i = 1; i < N; ++i) {
        P[i] = P[i-1]*p[N-1]%MOD;
        PP[i] = PP[i-1]*pp[N-1]%MOD;
    }
    scanf("%lld %lld", &q, &n);
    LL res = 0;
    for (int i = 1; i <= q; ++i) {
        LL ans = -(f(n%(MOD-1))-F(n%(MOD-1)))*invsqrt17%MOD;
        ans = (ans + MOD) % MOD;
        res ^= ans;
        n ^= ans*ans;
    }
    printf("%lld\n", res);
    return 0;
}
The 2019 Asia Nanchang First Round Online Programming Contest The Nth Item的更多相关文章
- The 2019 Asia Nanchang First Round Online Programming Contest
		传送门 A. Enju With math problem 题意: 给出\(a_1,\cdots,a_{100}\),满足\(a_i\leq 1.5*10^8\). 现在问是否存在一个\(pos\), ... 
- The 2019 Asia Nanchang First Round Online Programming Contest  C(cf原题,线段树维护矩阵)
		题:https://nanti.jisuanke.com/t/41350 分析:先将字符串转置过来 状态转移,因为只有5个状态,所以 i 状态到 j 状态的最小代价就枚举[i][k]->[k][ ... 
- The 2019 Asia Nanchang First Round Online Programming Contest  E. Magic Master
		题目链接:https://nanti.jisuanke.com/t/41352 题目意思还是好理解的,看过的人不多,感觉是被通过量吓到了.其实就是个水题,反向模拟就好了, 用队列模拟,反向模拟,它要放 ... 
- The 2019 Asia Nanchang First Round Online Programming Contest  B. Fire-Fighting Hero
		题目链接:https://nanti.jisuanke.com/t/41349 题意:有一个灭火英雄,和一个灭火团队,一个人与一个团队比较. 灭火英雄到其他灭火点的最短路最大值,与一个团队到其他灭火点 ... 
- H. The Nth Item(The 2019 Asia Nanchang First Round Online Programming Contest)
		题意:https://nanti.jisuanke.com/t/41355 给出N1,计算公式:A=F(N)Ni=Ni-1 ^ (A*A),F为类斐波那契需要矩阵快速幂的递推式. 求第k个N. 思路: ... 
- E.Magic Master(The 2019 Asia Nanchang First Round Online Programming Contest)
		直接模拟orhttps://blog.csdn.net/liufengwei1/article/details/100643831 
- The 2019 Asia Nanchang First Round Online Programming Contest(B,E)
		B. Fire-Fighting Hero 题意:一个消防员和多个队伍比赛,比较所有地方的最短路的最大值,消防员最后的值要乘1/C,求胜利的一方的最短路的最大值是多少.一直没读懂正确题意(内疚). 思 ... 
- The 2019 Asia Nanchang First Round Online Programming Contest B Fire-Fighting Hero(阅读理解)
		This is an era of team success, but also an era of heroes. Throughout the ages, there have been nume ... 
- The 2019 Asia Nanchang First Round Online Programming Contest C. Hello 2019(动态dp)
		题意:要找到一个字符串里面存在子序列9102 而不存在8102 输出最小修改次数 思路:对于单次询问 我们可以直接区间dpOn求出最小修改次数 但是对于多次询问 我在大部分题解看到的解释一般是用线段树 ... 
随机推荐
- 我的Java之路
			前言: 之前在学习python,刚开始的时候跟多数小白一样学习一些基础的知识,比如数据类型,用法,基本的语言结构,学了一段时间实在是学习不下去了,真是太TMD的无聊了,很多方法都记不住,也不知道学了这 ... 
- sudo权限配置
			首先要禁止root的用户登录ssh 在ssh配置文件里面把root用户no掉,一般公司不允许用第三方软件直接root登陆. 一.linux给用户添加sudo权限: 有时候,linux下面运行sudo ... 
- 038 Android Magicindicator开源框架实现viewpager底部圆形指示器
			1.Magicindicator介绍 Magicindicator是一个强大.可定制.易扩展的 ViewPager 指示器框架.是ViewPagerIndicator.TabLayout.PagerS ... 
- Practice
			一.简介 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的 ... 
- 1byte、1KB、4KB,1MB、1GB用16进制表示的范围。任意地址范围求字节数
			1byte.1KB.4KB,1MB.1GB用16进制表示的范围.任意地址范围求字节数 2018-02-12 18:27:48 望那伊人 阅读数 5032更多 分类专栏: 计算机相关 版权声明:本文 ... 
- Consul作为SpringCloud配置中心
			一.背景介绍 在分布式系统中动态配置中,可以避免重复重启服务,动态更改服务参数等.一句话非常重要. 另外一篇文章也是这样说的,哈哈. Consul 作为Spring 推荐的分布式调度系统其也具备配置中 ... 
- ELK搜索条件
			1.要搜索一个确切的字符串,即精确搜索,需要使用双引号引起来:path:”/app/logs/nginx/access.log” 2.如果不带引号,将会匹配每个单词:uid token 3.模糊搜索: ... 
- Eva 剧情解析
			Eva 剧情解析 来源 https://zhuanlan.zhihu.com/p/20864898 [0.写在前面的话] 相信和我年龄差不多的小伙伴们对<新世纪福音战士>( <Neo ... 
- Java 面向对象_接口
			接口定义 接口就是多个类的公共规范 接口是一种引用数据类型, 最重要的内容是其中的抽象方法 定义格式: public interface MyInterfaceAbstract { // 这是一个抽象 ... 
- 【转载】Sqlserver存储过程中使用Select和Set给变量赋值
			Sqlserver存储过程是时常使用到的一个数据库对象,在存储过程中会使用到Declare来定义存储过程变量,定义的存储过程变量可以通过Set或者Select等关键字方法来进行赋值操作,使用Set对存 ... 
