码迷,mamicode.com
首页 > 其他好文 > 详细

Codeforces Round #459 (Div. 2)

时间:2018-01-30 12:33:33      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:技术   位置   inline   斐波那契   return   col   map   lin   ring   

人生第一次CF炸裂掉了13的rating,只写了两道签到题,真的菜

T1:

输出一个长度为n的字符串,对于第i位,如果i是斐波那契数,输出O 否则输出o

技术分享图片
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cstdlib>
 5 #include<cmath>
 6 #include<algorithm>
 7 #include<queue>
 8 #include<vector>
 9 #include<map>
10 #define inf 2139062143
11 #define ll long long
12 #define MAXN
13 #define MOD
14 using namespace std;
15 inline int read()
16 {
17     int x=0,f=1;char ch=getchar();
18     while(!isdigit(ch)) {if(ch==-) f=-1;ch=getchar();}
19     while(isdigit(ch)) x=x*10+ch-0,ch=getchar();
20     return x*f;
21 }
22 int n,a=1,b=1,c;
23 bool hsh[1001];
24 int main()
25 {
26     n=read();
27     hsh[1]=1;
28     while(c<=n) c=a+b,a=b,b=c,hsh[c]=1;
29     for(int i=1;i<=n;i++)
30         if(hsh[i])cout<<O;
31         else cout<<o;
32 }
View Code

T2:

一个map就搞定的事

技术分享图片
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cstdlib>
 5 #include<cmath>
 6 #include<algorithm>
 7 #include<queue>
 8 #include<vector>
 9 #include<map>
10 #define inf 2139062143
11 #define ll long long
12 #define MAXN 1010
13 #define MOD
14 using namespace std;
15 inline int read()
16 {
17     int x=0,f=1;char ch=getchar();
18     while(!isdigit(ch)) {if(ch==-) f=-1;ch=getchar();}
19     while(isdigit(ch)) x=x*10+ch-0,ch=getchar();
20     return x*f;
21 }
22 int n,m;
23 char str[MAXN][15];
24 map <string,int> mp;
25 int main()
26 {
27     char ch[30],k[30];
28     string s;s+=;;
29     n=read(),m=read();
30     for(int i=1;i<=n;i++)
31     {
32         scanf("%s %s",str[i],ch);
33         mp[ch+s]=i;
34     }
35     for(int i=1;i<=m;i++)
36     {
37         scanf("%s %s",ch,k);
38         printf("%s %s #%s\n",ch,k,str[mp[k]]);
39     }
40 }
View Code

T3:

考试的时候石乐志

对于一个串求有几个子串是pretty的

一个串是pretty时它的括号是匹配的(?可以转化为左括号或右括号)

思路:

就是根据一个性质来判断每个子串是否pretty

对于一个串s 它pretty

当且仅当 它有偶数位,对于任意两个字符之间的一个位置 位置左侧的"("数量+"?"数量>=")"数量 位置右侧的 ")"数量+"?"数量>="("数量

然后预处理出这两个数组就行了

技术分享图片
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cmath>
 4 #include<cstdlib>
 5 #include<cstring>
 6 #include<algorithm>
 7 #include<vector>
 8 #include<queue>
 9 #define inf 2139062143
10 #define ll long long
11 #define MAXN 5010
12 using namespace std;
13 inline int read()
14 {
15     int x=0,f=1;char ch=getchar();
16     while(!isdigit(ch)) {if(ch==-) f=-1;ch=getchar();}
17     while(isdigit(ch)) {x=x*10+ch-0;ch=getchar();}
18     return x*f;
19 }
20 bool l[MAXN][MAXN],r[MAXN][MAXN],f;
21 int n,tmp;
22 char ch[MAXN];
23 int main()
24 {
25     scanf("%s",ch+1);n=strlen(ch+1);
26     for(int i=1;i<=n;i++)
27     {
28         f=tmp=0;
29         for(int j=i;j<=n;j++) 
30         {
31             if(ch[j]==)) tmp--;
32             else tmp++;
33             if(tmp<0) f=1;
34             l[i][j]=f;
35         }
36     }
37     for(int i=1;i<=n;i++)
38     {
39         f=tmp=0;
40         for(int j=i;j>=1;j--) 
41         {
42             if(ch[j]==() tmp--;
43             else tmp++;
44             if(tmp<0) f=1;
45             r[j][i]=f;
46         }
47     }
48     int ans=0;
49     for(int i=1;i<=n;i++)
50         for(int j=i+1;j<=n;j+=2)
51             if(!l[i][j]&&!r[i][j]) ans++;
52     printf("%d",ans);
53 }
View Code

T4:

 

Codeforces Round #459 (Div. 2)

标签:技术   位置   inline   斐波那契   return   col   map   lin   ring   

原文地址:https://www.cnblogs.com/yyc-jack-0920/p/8383468.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!