With the SCPC2015 getting closer, Noura Boubou, SCPC Head of Media, was very busy to the extent of not having time to recharge her phone's credit balance. However, her best friend, Nicole, was kind enough to transfer her own credit for the sake of keeping Noura online 24/7.
The phone credit transfer system in Syria works in the following way: Each successful transfer operation withdraws 25 extra credit units from the sender's balance, but it doesn't cost anything when a transfer operation is unsuccessful due to non sufficient credit balance.
Given the log of credit transfer requests and the response from the system to each request, in the form: Amount of transfer, and result of operation (either successful or unsuccessful), can you find out the number of possible initial credit balance values that Nicole could have had which satisfy the given log file?
Note that the initial credit balance is always a non negative integer.
The first line of input contains an integer T (1 ≤ T ≤ 256), the number of test cases.
The first line of each test case contains an integer N (1 ≤ N ≤ 105), the number of operations in the log of credit transfer requests.
Each of the following N lines contains an integer mi (1 ≤ mi ≤ 106), the amount of credit to transfer, followed by .
- { + } denotes a successful operation.
- { - } denotes an unsuccessful operation.
Each log contains at least one unsuccessful operation.
For each test case, print a single line that contains the number of possible initial credit balance values that Nicole could have had.
3 3 512 - 128 + 256 + 4 80 + 70 + 200 - 150 + 3 100 - 100 - 540 -
103 50 125
Warning: large Input/Output data, be careful with certain languages.
英语差,都不懂题意怪我喽,硬生生的凑答案,WA5次之后终于过了,才知道long loong最大值不是0x3f3f3f3f,真心菜。不解释了,解释不清,看代码吧。
代码实现:
#include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdio> #define ll long long #define mset(a,x) memset(a,x,sizeof(a)) using namespace std; const double PI=acos(-1); const int inf=0x3f3f3f3f; const double esp=1e-6; const int maxn=100005; const int mod=1e9+7; int dir[4][2]={0,1,1,0,0,-1,-1,0}; ll gcd(ll a,ll b){return b?gcd(b,a%b):a;} ll lcm(ll a,ll b){return a/gcd(a,b)*b;} ll inv(ll b){if(b==1)return 1; return (mod-mod/b)*inv(mod%b)%mod;} ll fpow(ll n,ll k){ll r=1;for(;k;k>>=1){if(k&1)r=r*n%mod;n=n*n%mod;}return r;} int main() { ll x,n,i,t; char ch[10]; scanf("%lld",&t); while(t--) { scanf("%lld",&n); ll sum=0,maxx=1e18,minn=0; for(i=0;i<n;i++) { scanf("%lld%s",&x,ch); if(ch[0]=='+') { sum=sum+x+25; minn=sum; } else { maxx=min(sum+x+25,maxx); } } printf("%lld\n",maxx-minn); } return 0; }
Since Judge Nicole Hosh moved to Egypt for her Computer Science Masters in AASTMT, in 2014, she has been training with coach Fegla and attending his camps in Egypt. She, also, set a number of problems for TCPC and JCPC and was a judge in LCPC and SCPC. Her best friend Noura was so proud of her so she was trying to convince her to start writing Codeforces Div. 2 round. After various attempts to convince her, Nicole finally agreed, and so, she started collecting some problems with different difficulties from her ex-contestant friends.
Judge Nicole collected 7 ideas for problems of different levels, she wants to create 5 problems for the next contest, one for each difficulty level, from A to E (difficulty 1 to 5). Given the difficulty level of the problems she currently has, she can merge the ideas of two problems, one of level x, and the other of level y to get a problem of level x + y.
For example, Judge Nicole can merge two problems of difficulties A and D, to get one problem of difficulty E (1 + 4 = 5).
Merging more than two problems into one will produce a problem with a long statement which is hard to explain, so she won’t do this (i.e., each problem is merged with another at most once). Also, she can’t merge a resultant problem again, and she can't use the same problem twice.
The first line of input contains an integer T (1 ≤ T ≤ 330), the number of test cases.
Each test case will contain only one string S of length 7. Each letter of the string represents the difficulty level of a problem (from A to E), 'A' is the easiest and 'E' is the hardest.
For each test case print "YES" if she can prepare a contest using the current problems, otherwise print "NO".
3 EBEABDA CEDEACA BDAAEAA
YES NO YES
Warning: large Input/Output data, be careful with certain languages.
题意通俗易懂,就是凑,两个凑一个,三个凑一个,各种模拟,最后自己都凌乱了,还好A到。
代码实现:
#include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdio> #define ll long long #define mset(a,x) memset(a,x,sizeof(a)) using namespace std; const double PI=acos(-1); const int inf=0x3f3f3f3f; const double esp=1e-6; const int maxn=100005; const int mod=1e9+7; int dir[4][2]={0,1,1,0,0,-1,-1,0}; ll gcd(ll a,ll b){return b?gcd(b,a%b):a;} ll lcm(ll a,ll b){return a/gcd(a,b)*b;} ll inv(ll b){if(b==1)return 1; return (mod-mod/b)*inv(mod%b)%mod;} ll fpow(ll n,ll k){ll r=1;for(;k;k>>=1){if(k&1)r=r*n%mod;n=n*n%mod;}return r;} int main() { int ans[105],i,j,k,l,n; char ch[15]; cin>>n; while(n--) { mset(ans,0); getchar(); for(i=0;i<7;i++) { scanf("%c",&ch[i]); ans[ch[i]-'A'+1]++; } int flag=0; for(i=1;i<=5;i++) //一种 { if(!ans[i]) flag=1; } if(flag) { for(i=0;i<7;i++) { for(j=i+1;j<7;j++) { int t1=ch[i]-'A'+1; int t2=ch[j]-'A'+1; int flag1=1; ans[t1]--;ans[t2]--; ans[t1+t2]++; for(k=1;k<=5;k++) { if(ans[k]==0) flag1=0; } if(flag1) flag=0; ans[t1]++;ans[t2]++;ans[t1+t2]--; } } if(flag) { for(i=0;i<7;i++) { for(j=i+1;j<7;j++) { for(k=0;k<7;k++) { for(l=k+1;l<7;l++) { if(i!=k&&i!=l&&j!=k&&j!=l) { int a=ch[i]-'A'+1,b=ch[j]-'A'+1,c=ch[k]-'A'+1,d=ch[l]-'A'+1,flag1=1; ans[a]--;ans[b]--;ans[a+b]++; ans[c]--;ans[d]--;ans[c+d]++; for(int w=1;w<=5;w++) { if(!ans[w]) flag1=0; } if(flag1) flag=0; ans[a]++;ans[b]++;ans[a+b]--; ans[c]++;ans[d]++;ans[c+d]--; } } } } } } } if(!flag) cout<<"YES"<<endl; else cout<<"NO"<<endl; } return 0; }
Noura has been looking for a restaurant to host the SCPC2015 celebration in Lattakia, she decided that the best method to pick a restaurant is according to the number of contestants that are living near it. Given a grid representing the map of Lattakia, each 3x3 cells represent a district, each district will consist of 3x3 areas. The center of each district is a restaurant (X), other cells can be:
‘.’ denotes an empty block. ‘*’ denotes a block full of people (4 persons)Help Noura decide which restaurant to choose by finding the maximum number of students living in a district.
The first line of input contains an integer T (1 ≤ T ≤ 256), the number of test cases.
The first line of each test case contains an integer N (1 ≤ N ≤ 100), the number of districts. Then follows three lines, each consists of3 × N characters, representing the map of the city of N districts.
For each test case, print the maximum number of students living in a district on a single line.
3 3 ***...*** .X.*X*.X. ***...*** 2 *.*.*. .X..X* *.*.*. 3 .*...**** *X**X**X* ...*..*.*
24 16 28
Warning: large Input/Output data, be careful with certain languages.
每一个x旁都有若干个*,每一个*能放4个人,问哪一个X旁能放的人最多。还是模拟。
代码实现:
#include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdio> #define ll long long #define mset(a,x) memset(a,x,sizeof(a)) using namespace std; const double PI=acos(-1); const int inf=0x3f3f3f3f; const double esp=1e-6; const int maxn=100005; const int mod=1e9+7; int dir[4][2]={0,1,1,0,0,-1,-1,0}; ll gcd(ll a,ll b){return b?gcd(b,a%b):a;} ll lcm(ll a,ll b){return a/gcd(a,b)*b;} ll inv(ll b){if(b==1)return 1; return (mod-mod/b)*inv(mod%b)%mod;} ll fpow(ll n,ll k){ll r=1;for(;k;k>>=1){if(k&1)r=r*n%mod;n=n*n%mod;}return r;} char map[4][1005]; int main() { int t,n,i,j,k,ans; cin>>t; while(t--) { mset(map,'\0'); cin>>n; for(i=0;i<3;i++) { scanf("%s",map[i]); } ans=0; int count=0; for(i=1;i<3*n;i+=3) { count=0; for(j=0;j<3;j++) { for(k=i-1;k<=i+1;k++) if(map[j][k]=='*') count+=4; } ans=max(ans,count); } cout<<ans<<endl; } return 0; }
While planning the SCPC2015 contest floor, each team has been assigned an area of a rectangular shape. The area covers the maximum region the team is allowed to move around during the contest.
When Noura saw the contest floor, she didn't like the rectangular shapes. She asked the organizers to reassign each team for a square shaped area instead of a rectangular one.
Given the sides of a rectangle, help the organizers find the square with minimum area, that covers the rectangle. To make it easier for the organizers, each side of the square must be parallel to one of the sides of the rectangle.
The first line of input contains an integer T (1 ≤ T ≤ 1024), the number of test cases.
Each test case contains two space-separated integers X, Y (1 ≤ X, Y ≤ 1000), the dimensions of the rectangular shaped area.
For each test case, print on a single line, the area of the square described in the problem statement.
3 3 3 5 7 12 6
9 49 144
Warning: large Input/Output data, be careful with certain languages.
输出最长边的平方。
代码实现:
#include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdio> #define ll long long #define mset(a,x) memset(a,x,sizeof(a)) using namespace std; const double PI=acos(-1); const int inf=0x3f3f3f3f; const double esp=1e-6; const int maxn=100005; const int mod=1e9+7; int dir[4][2]={0,1,1,0,0,-1,-1,0}; ll gcd(ll a,ll b){return b?gcd(b,a%b):a;} ll lcm(ll a,ll b){return a/gcd(a,b)*b;} ll inv(ll b){if(b==1)return 1; return (mod-mod/b)*inv(mod%b)%mod;} ll fpow(ll n,ll k){ll r=1;for(;k;k>>=1){if(k&1)r=r*n%mod;n=n*n%mod;}return r;} int main() { int n,x,y; cin>>n; while(n--) { cin>>x>>y; x=max(x,y); cout<<x*x<<endl; } return 0; }
After Noura's brother, Tamim, finished his junior training, coach Fegla was impressed with his progress. He told Noura that if Tamim would solve the following problem in SCPC2015 and yet does not qualify to the ACPC2015, he will give him a chance to participate unofficially in it.
The problem goes as follows:
Given L and R, how many integers between them have a prime number of ones in their binary representation?
Can you help Tamim participate in the ACPC2015?
The first line of input contains an integer T (1 ≤ T ≤ 105), the number of test cases.
Each test case will consist of two space - separated integers: L and R (0 ≤ L ≤ R ≤ 105).
For each test case, print the number of integers between L and R that have a prime number of ones in their binary representation.
3 2 10 1 19 3 101
6 13 65
Warning: large Input/Output data, be careful with certain languages.
英语不好,不懂题意,怪我喽。还是猜出来的,二进制数中1的个数为质数就是符合要求i的数。
代码实现:
#include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<cstdio> #define ll long long #define mset(a,x) memset(a,x,sizeof(a)) using namespace std; const double PI=acos(-1); const int inf=0x3f3f3f3f; const double esp=1e-6; const int maxn=100005; const int mod=1e9+7; int dir[4][2]={0,1,1,0,0,-1,-1,0}; ll gcd(ll a,ll b){return b?gcd(b,a%b):a;} ll lcm(ll a,ll b){return a/gcd(a,b)*b;} ll inv(ll b){if(b==1)return 1; return (mod-mod/b)*inv(mod%b)%mod;} ll fpow(ll n,ll k){ll r=1;for(;k;k>>=1){if(k&1)r=r*n%mod;n=n*n%mod;}return r;} int main() { int t,l,r,map[100005],i,j,k,f[30]; mset(map,0); map[1]=0;map[0]=0; mset(f,0); f[2]=f[3]=f[5]=f[7]=f[11]=f[13]=f[17]=1; for(i=2;i<100003;i++) { int temp=i; int sum=0; while(temp) { if(temp%2==1) sum++; temp/=2; } if(f[sum]==1) map[i]=map[i-1]+1; else map[i]=map[i-1]; } scanf("%d",&t); while(t--) { scanf("%d%d",&l,&r); cout<<map[r]-map[l-1]<<endl; } return 0; }