2023.3.10
这几天讲的倍增捏(一开始以优化 dp 为主,现在几乎纯倍增,6)。然后发现我不会快速幂。
贴一个板子。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll ans = 1;
ll a, b, p;
ll aa, bb, mod;
int main()
{
scanf("%lld%lld%lld", &a, &b, &p);
aa = a;
bb = b;
mod = p;
while(b)
{
if(b % 2) ans = ans * a % p;
a = a * a % p;
b /= 2;
}
printf("%lld", ans % p);
return 0;
}
3.09 模拟赛 T2,洛谷:P3509 ZAB-Frog
正解是倍增 + 单调队列。但是对于倍增最后空间会卡,所以要开动态数组,这里没有太理解,想明白了再补过来思路。先存一下码。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N = 1000010;
ll m;
int n, k;
ll a[N], nex[N], f[N], ans[N];
int main()
{
scanf("%d%d%lld", &n, &k, &m);
for(int i = 1; i <= n; i ++ ) scanf("%lld", &a[i]);
int head = 1, tail = k + 1;
nex[1] = k + 1;
for(int i = 2; i <= n; i ++ )
{
while(tail + 1 <= n && a[i] - a[head] > a[tail + 1] - a[i]) head ++, tail ++;
if(a[i] - a[head] >= a[tail] - a[i]) nex[i] = head;
else nex[i] = tail;
}
for(int i = 1; i <= n; i ++ ) ans[i] = i;
while(m > 0)
{
if(m % 2 == 1) for(int i = 1; i <= n; i ++ )ans[i] = nex[ans[i]];
m /= 2;
for(int i = 1; i <= n; i ++ ) f[i] = nex[i];
for(int i = 1; i <= n; i ++ ) nex[i] = f[f[i]];
}
for(int i = 1; i <= n; i ++ ) printf("%lld ", ans[i]);
return 0;
}
本文作者:Moyyer_suiy
本文链接:https://www.cnblogs.com/Moyyer-suiy/p/17204504.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步