admin管理员组文章数量:1794759
cf
源链接:
。。最近不知道为什么,,觉得做题目毫无状态。。略微迷茫。。
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_JUDGEfreopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
#endifint 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_JUDGEfreopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
#endifint 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_JUDGEfreopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
#endifll 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_JUDGEfreopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
#endifwhile(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){ //invalidok=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的题质量是真的好。。。
本文标签: cf
版权声明:本文标题:cf 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1692539522a144445.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论