Codeforces Round #397 by Kaspersky Lab and Barcelona Bootcamp (Div. 1 + Div. 2 combined)

本文提供了三道算法竞赛题目的解答思路及代码实现:A题利用欧拉回路判断;B题通过模拟解决字符串处理问题;C题则关注特定条件下的数学运算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

A

欧拉回路即可

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

using namespace std;
#define qq 1e5 + 10
#define REP(i, x, n)	for(int i = x; i < n; ++i)
#define pb push_back
#define mk make_pair
#define LL long long
map<string, int> mp;
int main(){
	int n;	cin >> n;
	string hom, con;
	string st;
	cin >> hom;
	REP(i, 0, n){
		cin >> st;
		hom = st.substr(0, st.find('-'));
		con = st.substr(st.find('>') + 1);
		mp[hom]++;
		mp[con]++;
	}
	map<string, int>:: iterator it;
	bool flag = true;
	for(it = mp.begin(); it != mp.end(); ++it)
		if((it->second % 2) == 1)	flag = false;
	if(flag)	puts("home");
	else	puts("contest");
	return 0;
}

B

按题意模拟

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

using namespace std;
#define qq 1e5 + 10
#define REP(i, x, n)	for(int i = x; i < n; ++i)
#define pb push_back
#define mk make_pair
#define LL long long
int num[30];
char st[1005];
int vis[1005];
int main(){
	scanf("%s", st);
	char ch = 'a';
	bool flag = true;
	REP(i, 0, (int)strlen(st)){
		if(vis[i])	continue;
		if(st[i] != ch){
			flag = false;
			break;
		}
		REP(j, i, (int)strlen(st)){
			if(st[i] == st[j])	vis[j] = 1;
		}
		ch++;
	}
	if(flag)	puts("YES");
	else	puts("NO");
	return 0;
}

C

就是考虑不成立的情况

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

using namespace std;
#define qq 1e5 + 10
#define REP(i, x, n)	for(int i = x; i < n; ++i)
#define pb push_back
#define mk make_pair
#define LL long long

int main(){
	int k, a, b;	scanf("%d%d%d", &k, &a, &b);
	int sum = a / k + b / k;
	if(a / k == 0){
		if(b % k != 0 || b == 0)	printf("-1\n");
		else	printf("%d\n", sum);
	}else if(b / k == 0){
		if(a % k != 0 || a == 0)	printf("-1\n");
		else	printf("%d\n", sum);
	}else{
		printf("%d\n", sum);
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值