A:deco的abs 水题,先%,然后相邻两个数min()一下差值。

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=;
const int Mod=;
int a[maxn]; ll ans;
int main()
{
int N,D;
scanf("%d%d",&N,&D);
for(int i=;i<=N;i++) scanf("%d",&a[i]),a[i]%=D;
for(int i=;i<=N;i++) {
int t=abs(a[i]-a[i-]);
ans+=min(t,D-t);
}
printf("%lld\n",ans);
return ;
}

B:deco的gcd .给出数组a[],求两两gcd之积。

当然如果是两两gcd之和,就是司空见惯的反演了。

没做过的,可以参考:

HDU - 4676 :Sum Of Gcd (莫队&区间gcd公式)      CodeForces - 645F:Cowslip Collections (组合数&&欧拉函数)

1,但是这里是之积,就有点烦。 我们可以把乘法变为加法,然后反演。

2,从另外一个角度看,由于是乘法,而且是积性函数,所以我们每个素数单独考虑。对于同一个素数p,其贡献是一个取min操作, 求出每个数有多少个p,然后基数统计一下前缀和,就可以算贡献了。  注意还要欧拉降幂(我忘了降幂GG了)。

处理每个数的素数及其幂次;

1,有根号算法,单词复杂度sqrt。

2,预处理sqrt以内的素数,128个。单词复杂度128;

3,素数筛的时候记录每个数的最小素数P[i]。那么可以一直除P[i],直到为1,复杂度<18;

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
const int Mod=;
int vis[maxn],p[maxn],cnt,ans=,K,P[maxn];
int qpow(int a,int x){
int res=; while(x){
if(x&) res=1LL*res*a%Mod;
x>>=; a=1LL*a*a%Mod;
} return res;
}
void init()
{
for(int i=;i<maxn;i++){
if(!vis[i]) p[++cnt]=i,Mn[i]=Mod,P[i]=i;
for(int j=;j<=cnt&&i*p[j]<maxn;j++){
vis[i*p[j]]=; P[i*p[j]]=p[j];
if(!(i%p[j])) break;
}
}
}
int G[maxn][];
int main()
{
int N,Q,x;
init();
scanf("%d",&N);
rep(i,,N) {
scanf("%d",&x);
while(x>){
int t=P[x],res=;
while(x%t==) x/=t,G[t][++res]++;
}
}
rep(i,,cnt){
int sum=;
for(int j=;j<=;j++){
int t=G[p[i]][j];
if(t<=) break;
(sum+=1LL*t*(t-)/%(Mod-))%=(Mod-);
}
ans=1LL*ans*qpow(p[i],sum)%Mod;
}
printf("%d\n",ans);
return ;
}

C:deco的str

题意:S中每个位置的值val为对应区间=T的循环同构数,求相邻位置的val的积的和。

思路:如何求每个位置的值,如果对S进行循环同构,复杂度会比较高。 所以考虑对T进行M次循环同构,生成了M个新的字符串{},记录每个新的字符串出现了多少次,然后每个位置的val=对应{}中字符串的出现次数。 那么显然可以hash来做,为了保险,可以用双hash。

题解的思路: 考虑对S循环同构。  不难想到,对于一个pos,它做出贡献的形式是,S[pos+1...]+S[...pos]=T,所以我们求出每个pos和T的前缀匹配的最长公共前缀长度L[]。每个pos和T的最长后缀长度P[]。 那么pos的贡献应该是max(0,P[pos]+L[pos]-lenT); (大概是这样)。

而求L,就是exKMP;  求P,就是把T倒序,S倒叙,再求一次exKMP即可。

#include<bits/stdc++.h>
#define ull unsigned long long
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
const int Mod=1e9+;
int seed=; ull p[maxn],h[maxn],fcy;
char a[maxn],b[maxn]; int ans;
unordered_map<ull,int>mp;
ull gethash(int L,int R)
{
return h[R]-h[L-]*p[R-L+];
}
int main()
{
int N,M; scanf("%s%s",a+,b+);
N=strlen(a+); M=strlen(b+);
if(N<M*) return puts(""),;
p[]=; rep(i,,N) p[i]=p[i-]*seed;
rep(i,,N) h[i]=h[i-]*seed+a[i]-'a'+;
rep(i,,M) fcy=fcy*seed+b[i]-'a'+;
mp[fcy]++;
rep(i,,M) fcy=(fcy-(b[i]-'a'+)*p[M-])*seed+b[i]-'a'+,mp[fcy]++;
rep(i,,N+-M-M) {
ull A=gethash(i,i+M-),B=gethash(i+M,i+M+M-);
if(mp.find(A)==mp.end()) continue;
if(mp.find(B)==mp.end()) continue;
ans=ans+1LL*mp[A]*mp[B]%Mod;
if(ans>=Mod) ans-=Mod;
}
printf("%d\n",ans);
return ;
}

牛客NOIP暑期七天营-提高组5的更多相关文章

  1. 牛客NOIP暑期七天营-提高组1

    牛客NOIP暑期七天营-提高组1 链接 A 边权可为0就排序建一条链子. 但是边权不为0 除了第一个有0的不行. x连向上一个比他小的数. 期间判断有无解. #include <bits/std ...

  2. 牛客NOIP暑期七天营-提高组6

    目录 A-积木大赛 题目描述 link 题解 代码 B-破碎的序列 题目描述 link 题解 C-分班问题 题目描述 link 题解 比赛链接 官方题解 A-积木大赛 题目描述 link 题解 标签: ...

  3. 牛客NOIP暑期七天营-提高组5+普及组5

    ————提高组———— 第一题:deco的abs 题目链接:https://ac.nowcoder.com/acm/contest/934/A 因为每个数都可以加任意次 d ,所以可以推出 0 < ...

  4. 牛客NOIP暑期七天营-提高组3

    第一题:破碎的矩阵 题目链接:https://ac.nowcoder.com/acm/contest/932/A    刚看到这题的时候感觉特别熟悉...诶,这不就是codeforces某场比赛的某某 ...

  5. 牛客NOIP暑期七天营-提高组2

    第一题:ACGT 题目链接:https://ac.nowcoder.com/acm/contest/931/A trie树.hash.map遍历  ①.trie树上的节点多记一个rest值表示还有多少 ...

  6. 牛客NOIP暑期七天营-提高组6C:分班问题 (组合数)

    题意:A班有N个人,B班有M个人,现在要组成一个新的班级C班,为了公平,从AB班各抽相同人数的人. 现在求所有方案中,人数之和是多少. 思路:即求Σ k*C(N,k)*C(M,k);    先忽略这个 ...

  7. 牛客NOIP暑期七天营-提高组2C:滑块(平衡树) (这里rope骗分)

    A:hash 或者 map 或者trie. #include<bits/stdc++.h> #define rep(i,a,b) for(int i=a;i<=b;i++) usin ...

  8. 牛客NOIP暑期七天营-提高组1 解题报告

    https://ac.nowcoder.com/acm/contest/920#question A 构造+双指针 发现m的限制是1e5,而点数是5e4,所以不能构造太多的边,思考一下最短路树的定义. ...

  9. 牛客NOIP暑期七天营-普及组2D

    链接:https://ac.nowcoder.com/acm/contest/926/D来源:牛客网 在一维坐标系中,给定 n条有颜色的线段,第 i条线段的左右端点分别为 li​和 ri​,此外它的颜 ...

随机推荐

  1. POJ-图论-最小生成树模板

    POJ-图论-最小生成树模板 Kruskal算法 1.初始时所有结点属于孤立的集合. 2.按照边权递增顺序遍历所有的边,若遍历到的边两个顶点仍分属不同的集合(该边即为连通这两个集合的边中权值最小的那条 ...

  2. django 中进程监控工具flower的使用

    工程结构:请参考https://www.cnblogs.com/apple2016/p/11425307.html flower官方文档:https://flower.readthedocs.io/e ...

  3. CMD使用的几个小技巧

    一.自定义窗口初始化大小 以前在Windows 7的时候感觉打开cmd时窗口初始化的大小还是比较合适的,但到Windows 10之后打开cmd窗口就很大一点都不适应----当然也可能是新电脑分辨率比较 ...

  4. JavaSE 面试题: 成员变量与局部变量

    JavaSE 面试题 成员变量与局部变量 public class Test { static int s; int i; int j; { int i = 1; i++; j++; s++; } p ...

  5. [转帖]Helm 3 使用 harbor 作为仓库存储 charts

    Helm 3 使用 harbor 作为仓库存储 charts https://www.cnblogs.com/innerpeacez/p/11252198.html 之前需要 使用tiller 现在貌 ...

  6. LOJ2874 JOISC2014 历史研究 分块、莫队

    传送门 看到出现次数自然地考虑莫队. 但是发现如果需要删除并动态维护答案的话,则要用一个堆来维护答案,增加了一个\(log\).但是加入操作却没有这个\(log\),所以我们考虑避免删除操作. 分块, ...

  7. linux权限管理(chown、chgrp、chomd)

    一.文件权限 我们以/etc/passwd 文件为例,用ll长列出其属性如下所示 ll /etc/passwd 每个文件针对每类访问访问者都定义了三种权限 文件类型中: p:表示命名管道文件 d:表示 ...

  8. PHP清除数组中有字符串空格的方法

    清除数组中字符串有空格的方法函数 function TrimArray($arr){ if (!is_array($arr)){ return $arr; } while (list($key, $v ...

  9. 局域网访问PHP项目网站 用IP地址进入

    先在apache中的 httpd.conf中将 Allow from 127.0.0.1 修改为Allow from all 如果你的是Allow from all的话就不需要改 然后再将 Docum ...

  10. ASP.NET SignalR 系列(八)之跨域推送

    前面几章讲的都是同域下的推送和订阅.这种讲讲如何跨域 对于SignalR来说,默认是不允许跨域的,因为安全问题.虽如此,但同时提供了跨域方案. 两种跨域方式: 1:JSONP2:CORS JSONP的 ...