cf_298

源链接: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 1000100
const 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 1000100
const 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 1000100
const 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 1000100
const 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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值