A水
#include<iostream> #include<cstdio> #include<cstring> using namespace std; char str[200]; int mapp[300]; int main(){ int i,k,j; char ccc[20]; char kbd[300]="qwertyuiopasdfghjkl;zxcvbnm,./\n"; for(i=0;i<strlen(kbd);i++){ mapp[kbd[i]]=i; } while(cin>>ccc){ while(cin>>str){ if(ccc[0]=='L'){ for(i=0;i<strlen(str);i++){ cout<<kbd[mapp[str[i]]+1]; } }else if(ccc[0]=='R'){ for(i=0;i<strlen(str);i++){ cout<<kbd[mapp[str[i]]-1]; } } } } return 0; }
B大水,居然可以不用二分
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int num[100003],n,m; long long sum[100003],qqq; int main(){ int i,j,k; while(scanf("%d",&n)!=EOF){ memset(sum,0,sizeof(sum)); for(i=1;i<=n;i++){ scanf("%d",&num[i]); sum[i]=sum[i-1]+num[i]; } scanf("%d",&m); while(m--){ scanf("%I64d",&qqq); int low=1,high=n,mid=n,res; while(low<=high){ mid=(low+high)/2; if(sum[mid]>=qqq){ res=mid; high=mid-1; }else{ low=mid+1; } } printf("%d\n",res); } } return 0; }
D DP,又是一个很好的dp题,一个由‘R’和‘W’构成的字符串中,w只能以连续k个存在,例如k=2,长度为4合法的字符串只有 RRWW WWRR WWWW RWWR RRRR,给出两个长度值a,b,问长度为[a,b]的串中合法的字符串有多少个。一开始我以为是一个排列组合问题,怎么做都无解,赛后发现是dp题(还是水题,哭)。dp[i]第i位有多少种字符串,当第i位选R时则dp[i]=dp[i-1],当第i位选W时则dp[i]=dp[i-k],所以转移方程为dp[i]=dp[i-1]+dp[i-k]
#include<cstdio> #include<iostream> #include<cstring> using namespace std; const int mod=1000000007; const int nMax=100005; long long dp[nMax+10]; int main(){ int tcs,k,a,b,i; while(cin>>tcs>>k){ memset(dp,0,sizeof(dp)); for(i=1;i<k;i++){ dp[i]=1; }dp[k]=2; for(i=k+1;i<=nMax;i++){ dp[i]=(dp[i-k]+dp[i-1])%mod; } for(i=2;i<=nMax;i++){ dp[i]=(dp[i]+dp[i-1])%mod; } while(tcs--){ cin>>a>>b; cout<<(dp[b]-dp[a-1]+mod)%mod<<endl; } } return 0; }
相关推荐
Codeforces Round #723 (Div. 2).md
上面代码跑出来的dp[n][m]是0,然后从(1,1)(1,2)(2,2)(2,3)这样的相与值是k (看懂ans+k是啥应该就懂了) 代码: int main() { std::ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); int ans=(1&...
传送门 题意: 开始位置在0,问能否跳到n+1位置 每步只能跳d 在1——n每个位置有方向,L,R,求d的最小值 思路: 只用找相邻两个R之间的最大值即可 代码: #include #include ...typedef long long l
就是把所有相等的数放到一个vector里,如果他出现大于2次,看最远的间距是否大于2即可,找到一个就可以 代码: #include #include #include #include #include #include #include #include #include #include #...
长度为n的字符串包含n−2n−2n−2个aaa和222个bbb,求按照字典序排列输出第kkk个字符串 解题思路 第一个bbb在倒数第二位有1个字符串,在倒数第三位有2个字符串…在倒数第nnn位时有n−1n-1n−1个字符串 可以根据第一...
E. Cyclic Components 题目链接-E. Cyclic Components 题目大意 给你nnn个点和mmm条边,求所构成图中单圈环的个数 ...并查集并查集并查集 很明显单圈环每个点的度都为222,所以我们可以用数组cnt[]记录每个点的度,...
Codeforces Round #629 (Div. 3) E.Tree Queries (DFS) 思路:若ai 在路径上 ,则ai的父结点一定在路径上,若ai是路径上某个结点的子结点,则ai的父结点一定在路径上,综上只需考虑ai的父节点就行了。对每个ai判断...
给两两节点放一个数字(0~n-2 唯一) 给你一棵树,求所有任意两节点相连的路以外的路上的数字的最小值最小 思路 构造 若一个点连了三条边及以上,则这个点的边从最小值开始赋值。其他边从最大点开始赋值。 证明:一...
给一个长度为n的数组,两种操作,一个是把任意一个ai变成ai+2a_i变成a_i+2ai变成ai+2,另一个是如果所有数都大于0,可以把所有数减1,问通过这些操作能否把所有数变为0 思路: 如果任意两个数之差为奇数,那么就...
输入一个正整数x,找出这样的2个正整数a和b,使得gcd(a,b)+lcm(a,b)=x 解题思路 找最特殊的情况a=1,b=x-1即可 这样a,b两个数最大公因数为1,最小公倍数x-1,满足题意√ 附上代码 #include #define int long long #...
B. Longest Palindrome time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard output Returning back to problem solving, Gildong is now studying about ...
将所有数字看成2进制,从最高位看起,如果第i位上为1的数只有一个的话,那么这个数必然对答案有贡献,就把它排在第一个,后面任意排。 例:11,6,4,0 二进制表示为:1011,110,100,0 右起第四位为1的只有1011,...
传说门 刚好今晚是中国场! 其实这道题比较水,但当时思路错,一心想着化简公式,浪费了好多时间a....#pragma GCC optimize(2) #include #define ll long long #define endl '\n' using namespace std; const int manx=
C(n-2,i-1)*C(j-1,n-2)*(i-1) __ j: n-1 -> m 我们发现内层循环,每次只是j加一,我们就可以只用一次组合数剩下的用差量表示 对于外层循环同理 只有(i-1) * C(n-2,i-1) i会每次加一。我们也只算一次剩下的用差量...
传送门 题意: 找规律,题意就是有多少种方式填充该图形 画两个就发现,输出n即可 代码: #include #include #include #include #include #include #include #include ...#define SZ(x) ((int)(x)
A #include using namespace std; typedef long long ll; int main(){ int t; cin>>t; while(t--){ ll x; cin>>x; cout<<1>>t; while(t--){ st.clear(); ll n; cin >>n;... ll re
题目链接:B. Longest Palindrome 题目 Returning back to problem solving, Gildong is now studying about palindromes. He learned that a palindrome is a string that is the same as its reverse....
惭愧,前几天刚学的dfs序判祖先关系都忘了用。。 这题我们先把所有点都变成父亲节点(根节点不变),这样只需要判所有节点是否在一条链上。 由于判断x是y的祖先:需要满足:st[x]<...const int M = 2e5+