首页 > 其他分享 >The 2021 Sichuan Provincial Collegiate Programming Contest

The 2021 Sichuan Provincial Collegiate Programming Contest

时间:2024-01-18 22:24:10浏览次数:37  
标签:Provincial return string Contest int s2 s1 Programming size

题目链接:The 2021 Sichuan Provincial Collegiate Programming Contest

A.Chuanpai

题意:定义每一张川牌包含两个数字x, y,并且1 <= x <=  y <= 6,求牌面上数字之和为 n 的牌种类

解题思路:签到,预处理枚举即可

查看代码
map<int, int> mp;
 
void init(){
	for(int i = 1; i <= 6; i ++){
		for(int j = i; j <= 6; j ++){
			mp[i + j] ++;
		}
	}	
}
void solve(){
	int n;
	cin >> n;
	cout << mp[n] << '\n';
}

 

B. Hotpot

题意:有n名游客,每名游客有一种喜欢的食材,定义操作:

1:当锅内有食材,吃掉全部食材,快乐值+1;

2:当锅内没有食材,向锅内加入食材

一共有m次操作,第n个人操作后由第一个人操作,求最后每个人的快乐值

解题思路:分类讨论即可,如果喜欢某种食材的人数为u

1:当u为偶数:那么只有当游客位于第偶数个喜欢这种食材的位置时才能增加快乐值

2:当u为奇数:

  (1)当游客位于第奇数个喜欢这种食材的位置,他只能增加 lun / 2 的快乐值

  (2)当游客位于第偶数个喜欢这种食材的位置,他可以增加 lun / 2 + (lun & 1)的快乐值

查看代码
 void solve(){
	int n, k, m;
	cin >> n >> k >> m;
	vector<int> a(n + 1), h(n + 1);
	map<int, int> mp, m1;
	for(int i = 1; i <= n; i ++){
		cin >> a[i];
		mp[a[i]] ++;
	}
	for(int i = 1; i <= n; i ++){
		m1[a[i]] ++;
		int lun = m / n + (m % n >= i);
		if(mp[a[i]] & 1){
			if(m1[a[i]] & 1){
				h[i] = lun / 2;
			}
			else{
			    h[i] = lun / 2 + (lun & 1);
			}
		} 
		else{
			if(m1[a[i]] & 1) h[i] = 0;
			else h[i] = lun;
		}
	}
	
	for(int i = 1; i <= n; i ++){
		cout << h[i];
		if(i != n) cout << ' ';
	}
	cout << '\n';
}

 

D. Rock Paper Scissors

题意:a,b玩石头剪刀布,每个人都有一些三种类型的牌,a先手,b可以看见a的牌然后出牌,a希望最小化b的得分,b喜欢最大化得分,求最终答案

(胜利+1, 平局不变, 失败-1)

解题思路:模拟即可,b的出牌策略和a的出牌方式无关,贪心的先求胜利,然后求平局,最后再减去失败的(好像写的很麻烦)

查看代码
 int a[5], b[5];
 
void solve(){
	for(int i = 1; i <= 3; i ++) cin >> a[i];
	for(int i = 1; i <= 3; i ++) cin >> b[i];
	int ans = 0;
	
	if(a[1] <= b[2]){
		b[2] -= a[1];
		ans += a[1];
		a[1] = 0;
	}
	else{
		ans += b[2];
		a[1] -= b[2];
		b[2] = 0;
		if(a[1] <= b[1]){
			b[1] -= a[1];
			a[1] = 0;
		}
		else{
			a[1] -= b[1];
			b[1] = 0;
			ans -= a[1];
			b[3] -= a[1];
			a[1] = 0;
		}
	}
//	cout << ans << '\n';
	if(a[2] <= b[3]){
		ans += a[2];
		b[3] -= a[2];
		a[2] = 0;
	}
	else{
		ans += b[3];
		a[2] -= b[3];
		b[3] = 0;
		if(a[2] <= b[2]){
			b[2] -= a[2];
			a[2] = 0;
		}
		else{
			a[2] -= b[2];
			b[2] = 0;
			ans -= a[2];
			b[1] -= a[2];
			a[2] = 0;
		}
	}
//	cout << ans << '\n';
	if(a[3] > 0){
		ans = ans + b[1] - b[2];
	}
	
	cout << ans << '\n';	
}

 

D. Nihongo wa Muzukashii Desu

题意:对应后缀查找替换

解题思路:模拟即可,注意划横线的特判(读题大挑战)

查看代码
 string check1(string &s){
	if(s.size() >= 5 && s.size() < 7){
		string s1 = s.substr(s.size() - 5, 5);
		if(s1 == "imasu"){
			string s2 = s.substr(0, s.size() - 5);
			return s2 + "tte";
		}
	}
	if(s.size() >= 6){
		string s1 = s.substr(s.size() - 6, 6);
		string s2 = s.substr(0, s.size() - 6);
		if(s1 == "rimasu"){
			return s2 + "tte";
		}
		else if(s1 == "mimasu"){
			return s2 + "nde";
		}
		else if(s1 == "bimasu"){
			return s2 + "nde";
		}
		else if(s1 == "nimasu"){
			return s2 + "nde";
		}
		else if(s1 == "kimasu"){
			return s2 + "ite";
		}
		else if(s1 == "gimasu"){
			return s2 + "ide";
		}
	}
	if(s.size() >= 7){
		string s1 = s.substr(s.size() - 7, 7);
		string s2 = s.substr(0, s.size() - 7);
		if(s1 == "chimasu"){
			return s2 + "tte";
		}	
		else if(s1 == "shimasu"){
			return s2 + "shite";
		}	
	}
}
 
void solve(){
	string s;
	cin >> s;
	if(s == "ikimasu"){
		cout << "itte\n";
		return;
	}
	string ans = check1(s);
	cout << ans << '\n';
}

 

K. K-skip Permutation

题意:构造一个长度为n的排列,要求P+ k = P(i + 1)

解题思路:贪心即可

查看代码
 int a[N], b[N];
 
void solve(){
	int n, k;
	cin >> n >> k;
	int u = 0;
	for(int i = 1; i <= n; i ++){
		if(b[i] == 0){
			for(int j = i; j <= n; j += k){
				a[++ u] = j;
				b[j] = 1;
			}
		}
	}
	
	for(int i = 1; i <= n; i ++) cout << a[i] << ' ';
}

 

L. Spicy Restaurant

题意:每家火锅店的火锅有一个辣度,每位顾客在其中一个火锅店,求到他们能接受的火锅店的最近距离是多少

解题思路:注意到 w 的范围很小,肯定从这里入手,先通过BFS求 dist[i][j],也就是第 i 个火锅店到辣度为 j 的火锅店的最短距离,然后类似于前缀和的方式处理一下 dist[i][j] = min(dist[i][j], dist[i][j - 1]),然后 dist[i][j] 就算第 i 家火锅店到小于等于 j 辣度的火锅店的最短距离

查看代码
 vector<int> edge[N];
int n, m, q, w[N];
int dist[N][110];
bool st[N];
 
void bfs(int u){
	queue<int> q;
	for(int i = 1; i <= n; i ++){
		if(w[i] == u){
			q.push(i);
			dist[i][u] = 0;
		}
	}//所有辣度为u的入队 
	
	while(!q.empty()){
		int x = q.front();
		q.pop();
		for(auto v : edge[x]){
			if(dist[v][u] == INF){
				q.push(v);
			}
			dist[v][u] = min(dist[v][u], dist[x][u] + 1);
		}//更新所有点到辣度为u的最小距离 
	}
}
 
void solve(){
	memset(dist, 0x3f, sizeof dist);
	cin >> n >> m >> q;
	for(int i = 1; i <= n; i ++) cin >> w[i];
	while(m --){
		int u, v;
		cin >> u >> v;
		edge[u].push_back(v);
		edge[v].push_back(u);
	}
	for(int i = 1; i <= 100; i ++){
		bfs(i);
	}
	for(int i = 1; i <= n; i ++){
		for(int j = 1; j <= 100; j ++){
			dist[i][j] = min(dist[i][j], dist[i][j - 1]);
		}
	}//因为是小于等于,求min 
	while(q --){
		int p, a;
		cin >> p >> a;
		if(dist[p][a] == INF) cout << -1 << '\n';
		else cout << dist[p][a] << '\n'; 
	}
}

 

M. True Story

题意:四个变量,n, k, x, p0,分别表示有 n 名乘客,他们距离机场的距离都是 x,飞机的起飞时间是p0,但是飞机会有k次改变起飞时间的通告,并且每次通告都是在 t[i] 发布,并且发布新的起飞时间 p[i],接下来输入 n 个整数 s[i],表示每位乘客的速度,最后分别读入 t[i],p[i]。同时,每位乘客只有在计算得出自己能赶上飞机后才会开始行动,求最终有多少人能赶上飞机

解题思路:先预处理出每位乘客到机场所需要的时间并且排序,然后 k 次更新起飞时间,计算当前距离起飞剩余的时间,然后每次二分来计算能赶上飞机的人数,然后求最大的能赶上飞机的人数

查看代码
 int n, k, x, p0;
int s[N], t[N], p[N], ned[N];
 
void solve(){
	cin >> n >> k >> x >> p0;
	for(int i = 1; i <= n; i ++){
		cin >> s[i];
		ned[i] = x / s[i];
		if(x % s[i] != 0) ned[i] ++;
	}
	for(int i = 1; i <= k; i ++) cin >> t[i];
	for(int i = 1; i <= k; i ++) cin >> p[i];
	sort(ned + 1, ned + n + 1);
	int r = upper_bound(ned + 1, ned + n + 1, p0) - ned - 1;
	for(int i = 1; i <= k; i ++){
		p0 = p[i] - t[i];
		r = max(r, upper_bound(ned + 1, ned + n + 1, p0) - ned - 1);
	}
	cout << r << '\n';
}

 

剩下的题目待补

标签:Provincial,return,string,Contest,int,s2,s1,Programming,size
From: https://www.cnblogs.com/RosmontisL/p/17973443

相关文章

  • 2021 ICPC Southeastern Europe Regional Contest
    Preface这场打的挺好,感觉在题目难度不小的情况下能写出10题还是挺猛的可惜最后时间差一点不然甚至能再写出来一个EA.KingofStringComparison签到,本来徐神跟我说写个二分+Hash,然后我库库上去一顿写刚抄完板子就被赶下来了直接从后往前扫,记录距离当前最近的不同的位置出现......
  • AtCoder Beginner Contest 336
    题目链接:AtCoderBeginnerContest336A-LongLoong题意:输出Long,其中'o'的数量等于n解题思路:签到(其实没看清楚题目wa了一发)查看代码voidsolve(){ intn; cin>>n; cout<<'L'; while(n--)cout<<'o'; cout<<"ng";}......
  • 2020-2021 ACM-ICPC Latin American Regional Programming Contest J. Job Allocator
    Preface今天因为下午被强行拉回老家了,而且没带电脑回去然后就变成了徐神和祁神两个人写,我拿个手机在后面口胡了3h最后变成了在缺我一个人的前提下还能4h过10题的情况,感觉就算我在的话最多就是快点过H然后把剩下的时间拿去写个J这场因为没啥参与就不写整场的博客了,把赛后写的这......
  • AtCoder Grand Contest 046 F Forbidden Tournament
    洛谷传送门AtCoder传送门太厉害了!!!!!!首先竞赛图有个性质,若存在环则一定存在三元环。先把DAG的情况(一条链)特判了。然后缩点。发现非链底的部分不能存在大小\(>1\)的SCC。所以枚举非链底的部分有多少点,转化为SCC的情况。发现对于任意点(设为\(1\)号点),它的前驱连成一条链......
  • Atcoder Beginner Contest 330 题解
    AtCoderBeginnerContest330题解A-CountingPasses签到voidShowball(){intn,l;cin>>n>>l;intcnt=0;for(inti=0;i<n;i++){intx;cin>>x;cnt+=(x>=l);}cout<<cnt<<endl;}B-Minimize......
  • AtCoder Beginner Contest 336
    B-CTZ难度:⭐题目大意给定一个数n,输出其二进制最后有几个连续的0;解题思路模拟一下就行;神秘代码#include<bits/stdc++.h>#defineintlonglong#defineIOSios::sync_with_stdio(false);cin.tie(0);cout.tie(0);#defineendl'\n'usingnamespacestd;......
  • AtCoder Beginner Contest 336
    AtCoderBeginnerContest336比赛链接A-LongLoong思路:简单的模拟代码:#include<bits/stdc++.h>usingnamespacestd;#defineintlonglongvoidsolve(){intn;//cin>>n;cin>>n;cout<<"L";for(inti=......
  • AtCoder Grand Contest 051 D C4
    洛谷传送门AtCoder传送门下文的点\(1,2,3,4\)对应原题面中的\(S,T,U,V\)。直接对无向图欧拉回路计数不太好做。考虑给边定向。枚举有\(i\)条边是从\(1\)到\(2\)的。那么\(2\to1\)有\(a-i\)条边。由于这个图必须满足每个点的入度等于出度,设\(j\)条\(......
  • AtCoder Beginner Contest 336
    AtCoderBeginnerContest336A-LongLoong#include<bits/stdc++.h>#defineendl'\n'//#defineintlonglongusingnamespacestd;voidsolve(){ intx; cin>>x; cout<<"L"; while(x--)cout<<"o&q......
  • 2021-2022 ACM-ICPC Latin American Regional Programming Contest
    Preface唉最近天天前期犯病,读错题占用大量机时还红温,纯在靠队友兜底H板题但刚开始因为没打印自己的KM板子就写个了MCMF上去,然后直接TLE飞,后面找了个别人的板子抄上去才过,I题一个傻逼题题意读错爆WA两发最后1h把L题扔给队友然后跑去看ECF滚榜直播了,只能说从此清北电的格局打开了......