Codeforces Round #429 (Div. 2)

A

判断一下某个字符是不是比k大

根据鸽笼原理即可知道至少有一个人会分到两种相同的颜色

#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <sstream>
#include <string>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <utility>

using namespace std;
#define LL long long
#define pb push_back
#define mk make_pair
#define mst(a, b)	memset(a, b, sizeof a)
#define REP(i, x, n)	for(int i = x; i <= n; ++i)
const int MOD = 1e9 + 7;
const int qq = 1e5 + 10;
int num[qq];
char st[qq];

int main(){
	int n, k;	scanf("%d%d", &n, &k);
	scanf("%s", st);
	for(int i = 0; i < strlen(st); ++i) {
		num[st[i] - 'a']++;
	}
	bool f = true;
	for(int i = 0; i < 26; ++i) {
		if(num[i] > k)	f = false;
	}
	if(!f)	puts("NO");
	else	puts("YES");
	return 0;
}

B

首先总和是奇数第一个人比赢

总和是偶数的情况,分两种

第一种数中存在奇数,这时可知奇数一定是偶数个, 那么可知总和变化 偶数(拿出奇数和)-> 奇数(拿出偶数和) ->奇数 此时第一个人把所有的拿完即可

第二种不存在奇数,这时第二个人赢

#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <sstream>
#include <string>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <utility>

using namespace std;
#define LL long long
#define pb push_back
#define mk make_pair
#define mst(a, b)	memset(a, b, sizeof a)
#define REP(i, x, n)	for(int i = x; i <= n; ++i)
const int MOD = 1e9 + 7;
const int qq = 1e6 + 10;
int num[qq];

int main(){
	int n;	scanf("%d", &n);
	int a = 0;
	for(int x, i = 0; i < n; ++i) {
		scanf("%d", num + i);
		if(num[i] % 2 == 1)	a++;
	}
	if(a == 0)	puts("Second");
	else	puts("First");
	return 0;
}

C

这题让最大的a给最小的b即可

#include <cstdio>
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <sstream>
#include <string>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <utility>

using namespace std;
#define LL long long
#define pb push_back
#define mk make_pair
#define mst(a, b)	memset(a, b, sizeof a)
#define REP(i, x, n)	for(int i = x; i <= n; ++i)
const int MOD = 1e9 + 7;
const int qq = 2e5 + 10;
LL a[qq];
struct Node {
	LL b, id;
	bool operator < (const Node &w) const {
		return b > w.b;
	}
}p[qq];
int ans[qq];

int main(){
	int n;	scanf("%d", &n);
	for(int i = 0; i < n; ++i) {
		scanf("%lld", a + i);
	}
	for(int i = 0; i < n; ++i) {
		scanf("%lld", &p[i].b);
		p[i].id = i;
	}
	sort(a, a + n);
	sort(p, p + n);
	for(int i = 0; i < n; ++i) {
		ans[p[i].id] = a[i];
	}
	for(int i = 0; i < n; ++i) {
		printf("%d ", ans[i]);
	}
	puts("");
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值