cf_298

来源:互联网 发布:waves gtr for mac 编辑:程序博客网 时间:2024/06/06 05:01

源链接:http://codeforces.com/contest/534

。。最近不知道为什么,,觉得做题目毫无状态。。略微迷茫。。

A:连A都错了。。真的是。。

题意就是把1-n个数排在一起,是的相邻的数相差不能为1.其实就是把奇数放在一起,,然后再把偶数放在一起。。可是事实是不能先放奇数,,比如n=4,如果先放奇数,那么就会有1 3 2 4这种情况,3和2就是差1了。。。。所以一定得先放偶数,,这样肯定不会错,,因为奇数是从1开始的,只要我们保证n=2的时候特判下,那就没问题了。。

#include<stdio.h>#include<iostream>#include<string>#include<string.h>#include<algorithm>#include<iomanip>#include<vector>#include<time.h>#include<queue>#include<stack>#include<iterator>#include<math.h>#include<stdlib.h>#include<limits.h>#include<set>#include<map>//#define ONLINE_JUDGE#define eps 1e-5#define INF 0x7fffffff#define FOR(i,a) for((i)=0;i<(a);(i)++)#define MEM(a) (memset((a),0,sizeof(a)))#define sfs(a) scanf("%s",a)#define sf(a) scanf("%d",&a)#define sfI(a) scanf("%I64d",&a)#define pf(a) printf("%d\n",a)#define pfI(a) printf("%I64d\n",a)#define pfs(a) printf("%s\n",a)#define sfd(a,b) scanf("%d%d",&a,&b)#define sft(a,b,c)scanf("%d%d%d",&a,&b,&c)#define for1(i,a,b) for(int i=(a);i<b;i++)#define for2(i,a,b) for(int i=(a);i<=b;i++)#define for3(i,a,b)for(int i=(b);i>=a;i--)#define MEM1(a) memset(a,0,sizeof(a))#define MEM2(a) memset(a,-1,sizeof(a))const double PI=acos(-1.0);template<class T> T gcd(T a,T b){return b?gcd(b,a%b):a;}template<class T> T lcm(T a,T b){return a/gcd(a,b)*b;}template<class T> inline T Min(T a,T b){return a<b?a:b;}template<class T> inline T Max(T a,T b){return a>b?a:b;}using namespace std;//#define ll __int64#define pi acos(-1.0);int n,m;#define Mod 1000000007#define N 510#define M 1000100const int size = 10010;const int mod = 9901;int a[M];int mmax;int num[1010];int ans;bool cmp(int x,int y){    return x>y;}int main(){#ifndef ONLINE_JUDGE    freopen("in.txt","r",stdin);//  freopen("out.txt","w",stdout);#endif    int t;    while(sf(n)!=EOF){        vector<int> v;        if(n == 2){            printf("1\n");            printf("1\n");            continue;        }        if(n == 3){            printf("2\n");            printf("1 3\n");            continue;        }        for(int i=2;i<=n;i+=2)            v.push_back(i);        for(int i=1;i<=n;i+=2)            v.push_back(i);        int size = (int)v.size();        printf("%d\n",size);        for(int i=0;i<size;i++)            printf("%d%c",v[i],i+1==size?'\n':' ');    }return 0;}

B:这题也墨迹好久。。真的不知道在干嘛。。

其实思路不难,因为我们要保证最后一个能经过中间的过渡到达,所以除去第一个和最后一个,对于从第二个数开始,我们就计划下,如果要使得数尽量大,那么我们就取v1+i*d,但是同时要在保证v2最后能到达,所以此时的最大值是v2+(t-i)*d,要满足题意,那么我们要在这两个数中取一个较小的,即res = Min(v1+i*d,v2+(t-i)*d),这样考虑就行。

#include<stdio.h>#include<iostream>#include<string>#include<string.h>#include<algorithm>#include<iomanip>#include<vector>#include<time.h>#include<queue>#include<stack>#include<iterator>#include<math.h>#include<stdlib.h>#include<limits.h>#include<set>#include<map>//#define ONLINE_JUDGE#define eps 1e-5#define INF 0x7fffffff#define FOR(i,a) for((i)=0;i<(a);(i)++)#define MEM(a) (memset((a),0,sizeof(a)))#define sfs(a) scanf("%s",a)#define sf(a) scanf("%d",&a)#define sfI(a) scanf("%I64d",&a)#define pf(a) printf("%d\n",a)#define pfI(a) printf("%I64d\n",a)#define pfs(a) printf("%s\n",a)#define sfd(a,b) scanf("%d%d",&a,&b)#define sft(a,b,c)scanf("%d%d%d",&a,&b,&c)#define for1(i,a,b) for(int i=(a);i<b;i++)#define for2(i,a,b) for(int i=(a);i<=b;i++)#define for3(i,a,b)for(int i=(b);i>=a;i--)#define MEM1(a) memset(a,0,sizeof(a))#define MEM2(a) memset(a,-1,sizeof(a))const double PI=acos(-1.0);template<class T> T gcd(T a,T b){return b?gcd(b,a%b):a;}template<class T> T lcm(T a,T b){return a/gcd(a,b)*b;}template<class T> inline T Min(T a,T b){return a<b?a:b;}template<class T> inline T Max(T a,T b){return a>b?a:b;}using namespace std;//#define ll __int64#define pi acos(-1.0);int n,m;#define Mod 1000000007#define N 510#define M 1000100const int size = 10010;const int mod = 9901;int main(){#ifndef ONLINE_JUDGE    freopen("in.txt","r",stdin);//  freopen("out.txt","w",stdout);#endif    int v1,v2;    int t,d;    while(sfd(v1,v2)!=EOF){        scanf("%d%d",&t,&d);        int ans = v1+v2;        if(v1>v2)            swap(v1,v2);        for(int i=2;i<t;i++){            int l = v1+(i-1)*d;            int r = v2+(t-i)*d;            ans += Min(l,r);        }        printf("%d\n",ans);    }return 0;}

C:C题还好,刚开始考虑的比较复杂了点,其实还是挺简单的,对于每个骰子,我们能求出它能够取的最小值和最大值,那么它的范围减去它能够取的值,就是不能够取的值了。所以我们考虑下最小值和最大值,其中最大值就是当其他骰子取1的时候,此时该骰子有最大值,为A-(n-1),当然这个值要小于它本身的最大点数;最小值的话就是当其他所有骰子为最大值时,此时它能够取的值,即A-(sum-a[i]),sum就是所有骰子的总点数,当然,这最小值要大于等于1.这样子的范围求出来后,那么求不能取的范围只要总范围减去能取的范围就行了。

#include<stdio.h>#include<iostream>#include<string>#include<string.h>#include<algorithm>#include<iomanip>#include<vector>#include<time.h>#include<queue>#include<stack>#include<iterator>#include<math.h>#include<stdlib.h>#include<limits.h>#include<set>#include<map>//#define ONLINE_JUDGE#define eps 1e-5#define INF 0x7fffffff#define FOR(i,a) for((i)=0;i<(a);(i)++)#define MEM(a) (memset((a),0,sizeof(a)))#define sfs(a) scanf("%s",a)#define sf(a) scanf("%d",&a)#define sfI(a) scanf("%I64d",&a)#define pf(a) printf("%d\n",a)#define pfI(a) printf("%I64d\n",a)#define pfs(a) printf("%s\n",a)#define sfd(a,b) scanf("%d%d",&a,&b)#define sft(a,b,c)scanf("%d%d%d",&a,&b,&c)#define for1(i,a,b) for(int i=(a);i<b;i++)#define for2(i,a,b) for(int i=(a);i<=b;i++)#define for3(i,a,b)for(int i=(b);i>=a;i--)#define MEM1(a) memset(a,0,sizeof(a))#define MEM2(a) memset(a,-1,sizeof(a))const double PI=acos(-1.0);template<class T> T gcd(T a,T b){return b?gcd(b,a%b):a;}template<class T> T lcm(T a,T b){return a/gcd(a,b)*b;}template<class T> inline T Min(T a,T b){return a<b?a:b;}template<class T> inline T Max(T a,T b){return a>b?a:b;}using namespace std;#define ll __int64#define pi acos(-1.0);ll n,m;#define Mod 1000000007#define N 510#define M 1000100const int size = 10010;const int mod = 9901;ll a[M];int main(){#ifndef ONLINE_JUDGE    freopen("in.txt","r",stdin);//  freopen("out.txt","w",stdout);#endif    ll A;    while(scanf("%I64d%I64d",&n,&A)!=EOF){        ll sum=0;        for(int i=1;i<=n;i++){            sfI(a[i]);            sum += a[i];        }        if(n == 1){            printf("%I64d\n",a[1]-1);            continue;        }        for(int i=1;i<=n;i++){            ll r = Min(A-(n-1),a[i]);            ll l = Max(A-(sum-a[i]),1ll);            ll res = a[i]-(r-l+1);            printf("%I64d%c",res,i==n?'\n':' ');        }    }return 0;}

D:D题是看了别人的代码,挺好理解的。模拟一下就行。对于每个握手的次数,它都有对应的一个人,那么我们开始遍历n个人,从握手次数0开始,然后握手次数+1,如果到了某个握手次数,发现没人是这个次数,那么就将其中三个人组队,握手次数-3,如果到了某个时候人数为负了,那么说明该序列是无效的。

#include<stdio.h>#include<iostream>#include<string>#include<string.h>#include<algorithm>#include<iomanip>#include<vector>#include<time.h>#include<queue>#include<stack>#include<iterator>#include<math.h>#include<stdlib.h>#include<limits.h>#include<set>#include<map>//#define ONLINE_JUDGE#define eps 1e-5#define INF 0x7fffffff#define FOR(i,a) for((i)=0;i<(a);(i)++)#define MEM(a) (memset((a),0,sizeof(a)))#define sfs(a) scanf("%s",a)#define sf(a) scanf("%d",&a)#define sfI(a) scanf("%I64d",&a)#define pf(a) printf("%d\n",a)#define pfI(a) printf("%I64d\n",a)#define pfs(a) printf("%s\n",a)#define sfd(a,b) scanf("%d%d",&a,&b)#define sft(a,b,c)scanf("%d%d%d",&a,&b,&c)#define for1(i,a,b) for(int i=(a);i<b;i++)#define for2(i,a,b) for(int i=(a);i<=b;i++)#define for3(i,a,b)for(int i=(b);i>=a;i--)#define MEM1(a) memset(a,0,sizeof(a))#define MEM2(a) memset(a,-1,sizeof(a))const double PI=acos(-1.0);template<class T> T gcd(T a,T b){return b?gcd(b,a%b):a;}template<class T> T lcm(T a,T b){return a/gcd(a,b)*b;}template<class T> inline T Min(T a,T b){return a<b?a:b;}template<class T> inline T Max(T a,T b){return a>b?a:b;}using namespace std;#define ll __int64#define pi acos(-1.0);int n,m;#define Mod 1000000007#define N 510#define M 1000100const int size = 10010;const int mod = 9901;queue<int> q[200005];int a[M];int main(){#ifndef ONLINE_JUDGE    freopen("in.txt","r",stdin);//  freopen("out.txt","w",stdout);#endif    while(scanf("%d",&n)!=EOF){    for(int i=0;i<=n;i++)    while(!q[i].empty()) q[i].pop();    int x;    for(int i=1;i<=n;i++){    scanf("%d",&x);    q[x].push(i);    }    int ok = 1,peo = 0;    for(int i=1;i<=n;i++){    while(1){    if(peo<0){//invalid    ok=0;    break;    }    if(!q[peo].empty()){    a[i] = q[peo].front();//    q[peo].pop();    peo++;    break;    }else{    peo -= 3;//3 people composes a team    }    }    if(!ok)    break;    }    if(!ok)    printf("Impossible\n");    else{    printf("Possible\n");    for(int i=1;i<=n;i++)    printf("%d%c",a[i],i==n?'\n':' ');    }    }return 0;}
CF的题质量是真的好。。。

0 0
原创粉丝点击