The Nth Item 南昌网络赛(递推数列,分段打表)

The Nth Item

\[
Time Limit: 1000 ms \quad Memory Limit: 262144 kB
\]

题意

给出递推式,求解每次 \(F[n]\) 的值,输出所有 \(F[n]\) 的 \(xor\) 值。

思路

对于线性递推数列,可以用特征方程求出他的通项公式,比如这题
\[
F[n] = 3F[n-1]+2F[n-2] \x^2 = 3x+2 \x = \frac{3\pm \sqrt{17}}{2}
\]
令 \(F[n] = C_1x_1^n + C_2x_2^n\)
将 \(F[0]\) 和 \(F[1]\) 带入
\[
\begin{aligned}
&\begin{cases}
C_1 + C_2 = 0 \C_1\frac{3+ \sqrt{17}}{2} + C_2\frac{3- \sqrt{17}}{2} = 1
\end{cases} \&\begin{cases}
C_1 = \frac{1}{\sqrt{17}}\C_2 = -\frac{1}{\sqrt{17}}
\end{cases}
\end{aligned}
\]
即 \(F[n] = \frac{1}{\sqrt{17}} \left[\left(\frac{3+\sqrt{17}}{2}\right)^n - \left(\frac{3-\sqrt{17}}{2}\right)^n \right]\)

\(\sqrt{17}\) 可以通过二次剩余来得到其中一个可能的解,\(524399943\) 就是一个解。
令 \(p = \frac{3+\sqrt{17}}{2},q=\frac{3-\sqrt{17}}{2}\),现在的问题就是解出 \(p^n\) 和 \(q^n\)。
首先因为 \(n\) 高达 \(1e18\),可以利用欧拉降幂,把 \(n\) 降到 \(2mod-1\) 级别内,也即是 \(2e9\) 附近。
可以利用 \(n = x*50000+y\),\(q^n = q^{x*50000} * q^y\),将 \(q\) 在 \(5e4\) 以内的幂打表出来,在打出 \(q\) 的幂为 \(k*5e4\) 的表,然后就可以做到 \(O(1)\) 查询。
对于 \(q\) 也是相同的做法。

/***************************************************************
    > File Name    : a.cpp
    > Author       : Jiaaaaaaaqi
    > Created Time : Wed 11 Sep 2019 10:01:20 PM CST
 ***************************************************************/

#include <map>
#include <set>
#include <list>
#include <ctime>
#include <cmath>
#include <stack>
#include <queue>
#include <cfloat>
#include <string>
#include <vector>
#include <cstdio>
#include <bitset>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <unordered_map>
#define  lowbit(x)  x & (-x)
#define  mes(a, b)  memset(a, b, sizeof a)
#define  fi         first
#define  se         second
#define  pb         push_back
#define  pii        pair<int, int>

typedef unsigned long long int ull;
typedef long long int ll;
const int    maxn = 1e5 + 10;
const int    maxm = 1e5 + 10;
const ll     mod  = 998244353;
const ll     INF  = 1e18 + 100;
const int    inf  = 0x3f3f3f3f;
const double pi   = acos(-1.0);
const double eps  = 1e-8;
using namespace std;

ll n, m;
int cas, tol, T;

ll fpow(ll a, ll b) {
    ll ans = 1;
    while(b) {
        if(b&1) ans = ans*a%mod;
        a = a*a%mod;
        b >>= 1;
    }
    return ans;
}
ll sqrt17 = 524399943, phiC = mod-1;
ll p, q, inv17;

ll ppow1[maxn], ppow2[maxn];
ll qpow1[maxn], qpow2[maxn];

void handle() {
    inv17 = fpow(sqrt17, mod-2);
    p = 1ll*(3ll+sqrt17)*fpow(2, mod-2)%mod, q = 1ll*(3ll-sqrt17+mod)*fpow(2, mod-2)%mod;
    ppow1[0] = qpow1[0] = 1;
    for(int i=1; i<=50000; i++) {
        ppow1[i] = ppow1[i-1]*p%mod;
        qpow1[i] = qpow1[i-1]*q%mod;
    }
    ppow2[0] = qpow2[0] = 1;
    ppow2[1] = ppow1[50000];
    qpow2[1] = qpow1[50000];
    for(int i=2; i<=50000; i++) {
        ppow2[i] = ppow2[i-1]*ppow1[50000]%mod;
        qpow2[i] = qpow2[i-1]*qpow1[50000]%mod;
    }
}

ll getp(ll n) {
    return ppow2[n/50000]*ppow1[n%50000]%mod;
}

ll getq(ll n) {
    return qpow2[n/50000]*qpow1[n%50000]%mod;
}

ll solve(ll n) {
    if(n >= phiC)   n = n%phiC+phiC;
    return inv17*(getp(n)-getq(n)+mod)%mod;
}

int main() {
    // freopen("in", "r", stdin);
    handle();
    scanf("%lld%lld", &n, &m);
    ll ans = 0;
    for(int i=1; i<=n; i++) {
        ll tmp = solve(m);
        m ^= tmp*tmp;
        ans ^= tmp;
    }
    printf("%lld\n", ans);
    return 0;
}

原文地址:https://www.cnblogs.com/Jiaaaaaaaqi/p/11509318.html

时间: 2024-10-29 19:12:40

The Nth Item 南昌网络赛(递推数列,分段打表)的相关文章

2019 ICPC 南昌网络赛

2019 ICPC 南昌网络赛 比赛时间:2019.9.8 比赛链接:The 2019 Asia Nanchang First Round Online Programming Contest 总结 // 史上排名最高一次,开场不到两小时队友各A一题加水题共四题,排名瞬间升至三四十名 // 然后后三小时就自闭了,一题都没有突破...最后排名211 hhhh ? ? B. Fire-Fighting Hero 题意 队友做的,待补. ? AC代码 #include<cstdio> #includ

ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval

ACM-ICPC 2019南昌网络赛I题 Yukino With Subinterval 题目大意:给一个长度为n,值域为[1, n]的序列{a},要求支持m次操作: 单点修改 1 pos val 询问子区间中某个值域的数的个数,连续的相同数字只记为一个.(即统计数字段的个数) 2 L R x y 数据范围: 1 ≤ n,m ≤ 2×10^5 1 ≤ a[i] ≤ n 解题思路: 连续重复的数字只记一次.所以考虑将每个数字段除第一个出现外的数字都删去(记为0).在读入操作的时候暴力模拟,同时维护

根据a(n)/a(n-1)的无理数极限逆推二阶线性递推数列公式

首先看这样一道题目: a(n)=6*a(n-1)-a(n-2),a1=1,a2=5,求b(n)=a(n+1)/a(n)的极限  数列通项两边除以a(n-1) 得: a(n)/a(n-1)=6-a(n-1)/a(n-2) 根据单调有界定理可以证明极限存在 单调性可以用数学归纳法证明,不再赘述 设极限为x 则x=6-1/x x^2-6*x+1=0 解一元二次方程得 x=3+2√2 我举这个例子,是因为,这个例子和2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络E题的数列很像,只不过在后面减了个

【UVA】12034-Race(递推,组合数打表)

递推公式,假设第一名有i个人并列,那么: f[n] = C(n,i) * f[n - i]; 打出1 ~ 1000的所有组合数,之后记忆化搜索,需要打表. 14026995 12034 Race Accepted C++ 0.032 2014-08-12 11:47:47 #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #include<vector&g

题目1081:递推数列 (矩阵快速幂解递推式)

题目1081:递推数列 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:5885 解决:800 题目描述: 给定a0,a1,以及an=p*a(n-1) + q*a(n-2)中的p,q.这里n >= 2. 求第k个数对10000的模. 输入: 输入包括5个整数:a0.a1.p.q.k. 输出: 第k个数a(k)对10000的模. 样例输入: 20 1 1 14 5 样例输出: 8359 来源: 2009年清华大学计算机研究生机试真题 1 #include<stdio.h> 2 #

a(n+1) = f[a(n)] 型递推数列的迭代作图(玩计算器玩出了问题)

把任意一个正数开平方再加 \(1\), 把得到的结果也开平方再加 \(1\), 不断算下去,最终总会得到 \( \frac{3+\sqrt{5}}{2} \approx 2.61804 \), 即: \( \sqrt{\cdots \sqrt{\sqrt{\sqrt{x}+1}+1}+1}+1 = \frac{3+\sqrt{5}}{2} \;\;\;\; (x>0) \) 这是某同学玩计算器时发现的,非常有意思.不管一开始给的数是多少,终最都会停在这个神奇的数上,它是黄金比 \( \frac{

[普通递推数列] 转自《信息学奥赛之数学一本通》

[普通递推数列] 问题描述 给出一个k阶齐次递推数列f[i]的通项公式 \[ f[i] = \prod_{j = 1}^k a_jf_{i-j} \] 以及初始值f[0], f[1], f[2], ··· , f[k - 1], 求f[n]. 输入格式 第一行两个整数n, k; 第二行k个整数,a[1] ~ a[k] 第三行k个整数,f[0] ~ f[k - 1] 输出格式 一行一个整数p, 是f[n] % 10000 的结果 example input 10 2 1 1 1 1 example

生成函数求解一般递推数列通项公式

目录 写在前面 范例 - 对斐波那契通项公式的推导 对一般递推数列通项公式的推导 写在前面 本文解出的通项公式十有八九与使用特征根方程接触的在形式上不同,但是其正确性可以保证. 如有强迫症请自行化简. 范例 - 对斐波那契通项公式的推导 设生成函数 \[ A=1+x+2x^2+3x^3+5x^4+... \] 不难发现,\(i-1\)项系数即为斐波那契数列第\(i\)项的值. 由于斐波那契数列递推式为 \[ F(i)=F(i-1)+F(i-2) \] 我们得到另外两个生成函数 \[ xA=x+x

19南昌网络赛L

校赛打杂没施展开. 题意:一开始给你一颗 (0,0)到(0,l)的树. 这棵树每一年会长出来三个幼芽(雾),长度均为l/4,方向分别是左转60,右转60,和不变. 年份<=14 考虑3^14直接暴力存边然后考虑每条边贡献.发现奇难无比. 考虑剪枝. 注意到如果一根树枝的被砍掉了那么他所有的孩子全都不算贡献了.妙啊!变成傻逼题. 抄一下板子. 1 #include <bits/stdc++.h> 2 using namespace std; 3 typedef double db; 4 c