2023年第六届广西大学生程序设计竞赛(热身赛)题解


比赛链接,可以继续提交代码

2023年第六届广西大学生程序设计竞赛(热身赛)

题目均来自去年的省赛原题

参考资料(知乎):第五届GXCPC广西大学生程序设计竞赛 部分题解(无CDK)

A题送分题,跳过


B 位运算lowbit函数

题目大意:

对一个数(二进制)进行操作,询问使其变成0的最短操作步骤。
操作方式:x+=lowbit(x) 或者 x−=lowbit(x)

解题思路:

经过观察

  • 单独的 “1” 只需经过一次操作即可转为 “0”,即x−=lowbit(x)
  • 连续的 “1” 只需经过两次次操作即可转为 “0”,比如
    1111 -> x+=lowbit(x) -> 10000 -> x−=lowbit(x) -> 0

为了更好处理(避免进位到最前面一位时需要前补0)

  • 可以先进行翻转(reverse),并在末尾加上两个字符 “00”。
  • 或者不翻转,直接在前面加上两个字符 “00”。

下面说的是翻转的思路,不翻转的话也同理:

  • 从左往右扫描字符串。如果扫描到一个字符为 ‘1’,就检查它右边的字符。
  • 如果右边的字符是 ‘0’,说明这是一个独立的 “1”,计数加一;
  • 如果右边的字符也是 ‘1’,说明这是一个连续的 “11”,就将这个连续段的第一个 ‘1’ 改为 ‘0’,并将前面的 ‘1’ 变成 ‘0’,直到遇到一个 ‘0’ 为止,再将最后一个 ‘0’ 变成 ‘1’。然后回退一格继续扫描。

参考代码c++

#include<iostream>
using namespace std;
int ans,sum;
string s;

int main(){
	cin>>s;
	s="00"+s;
	for (int i=s.size()-1;i>=0;i--){
		if (s[i]=='1') sum++;
		else if (s[i]=='0'&&sum){
			ans++;
			if (sum>1) s[i]='1',sum=1;
			else sum=0;
		}
	}
	cout<<ans<<endl;
}

C 家庭作业

题目大意:

有很多份作业要写,每份作业字数(所需时间)不同。但是可以先写完一份,然后其他的抄这一份,当然不同作业抄是需要花不同时间的。

解题思路:

首先我们肯定至少要写最多的那一份的数量的字,其余的我们都可以用复制粘贴来解决。

但不是说我们先把最多的那一份作业写完,比如三个作业子数是100,200,300对应的复制时间是99,199,1。那么显然我们先写完200的字,再复制给作业1和3,最后补足作业三缺少的字更省时间。

既然我们要写的字数已经固定,那初步时间就可以知道了,然后只有第一份是不能粘贴的,所以我们第一份作业选的就是复制时间用时最多的那一个。

即总时间是:最大字数+除去一份最大复制时间后其它复制时间的总和。

参考代码c++

#include<iostream>
using namespace std;
long n,cnt,ans,a,b;

int main(){
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>a;
		cnt=max(cnt,a);
    }
	for(int i=0;i<n;i++){
		cin>>b;
		cnt+=b;
		ans=max(ans,b);
	}
	cout<<cnt-ans;
	return 0;
}

D 不嫉妒

题目大意:

有两个人,相同商品在他们眼中价值不同。需要对前i件商品中,自己的东西价值 和 对方的东西价值 进行比较。

解题思路:

题目很长,但也还是是签到题。

记录一下两边自己物品在自己眼里的最大值和在对面眼里的最大值,以及对面认为我的价值最大和最小的两个物品。

  • 只要两边都认为自己的东西价值最大,就输出EF。
  • 如果对面物品减去最小的货物后价值比我的小,输出EFX。
  • 如果对面物品减去最大的货物后价值比我的小,输出EF!。
  • 其它情况输出E。

c++要注意 输入、输出和换行 优化,不然过不去。

一开始想到的是使用pair处理,但后来发现没必要。

参考代码c++

#include <iostream>
using namespace std;
//xa、ya表示自己拥有的自己眼里物品总价值,xb、yb表示自己拥有的对面眼里物品总价值
//maxx、maxy表示对面认为我的价值最高的物品,minx、miny表示对面认为我的价值最低的物品
long xa, xb, ya, yb, maxx, maxy, minx = 1e6, miny = 1e6, n, c, e, b;

int main() {
	cin >> n;
	while (n--) {
		scanf("%d%d%d", &c, &e, &b);
		if (!b) {
			xa += c;
			xb += e;
			maxx = max(maxx, e);
			minx = min(minx, e);
		} else {
			ya += c;
			yb += e;
			maxy = max(maxy, c);
			miny = min(miny, c);
		}
		if (xa >= ya && yb >= xb)
			printf("EF\n");
		else if ((ya - miny <= xa) && (xb - minx <= yb))
			printf("EFX\n");
		else if ((ya - maxy <= xa) && (xb - maxx <= yb))
			printf("EF1\n");
		else
			printf("E\n");
	}
	return 0;
}

以下为D题的翻译:

D 不嫉妒

题目描述

本题是经济学和计算机科学中一个基本的问题:如何公平地分配物品给竞争的代理人。

问题假设有一个包含 m 件物品的集合 M,目标是以公平的方式将这些物品分配给 n 个代理人。

“公平” 的概念之一是不嫉妒。具体来说,如果代理人 i 对于代理人 j 拥有的物品组合 Xj 的价值高于其自身拥有的物品组合 Xi 的价值,则称代理人 i 嫉妒代理人 j。

其中,每个代理人都对每个物品 j 感兴趣,并对其有一个价值 wi,还对一组物品 S 感兴趣,并将其中的所有物品的价值求和表示为 Wi(S)。

分配是将 M 分成不相交的子集 X1, …, Xn 的过程,其中 Xi 是分配给代理人 i 的物品集合。

本题涉及到三种分配方式:EF(嫉妒零),EFX(嫉妒任意物品),EF1(嫉妒一件物品)。在第一个最优先且最好的分配方式 EF 中,不存在一个代理人会嫉妒另一个代理人;在第二个分配方式 EFX 中,代理人 i 可以妒嫉代理人 j,但是只要从代理人 j 拥有的一组物品中移除任何一个物品,这种妒嫉就会消失;在第三个分配方式 EF1 中,代理人 i 也可以嫉妒代理人 j,但是只要从代理人j所拥有的一组物品中移除任何一个物品,这种妒嫉就会消失。

在本题中,只考虑两个代理人 Colin 和 Eva 的情况。开始时,他们都没有任何物品。然后进行 m 次操作,每次操作提供三个值 ci, ei 和 bi,分别表示该物品在 Colin 和 Eva 视角下的价值,以及该物品分配给 Colin 还是 Eva。每次操作之后,需要判断当前分配方式的优先级。最高的是 EF,其次是 EFX,再次是 EF1,如果都不满足,则最差的是嫉妒。

输入描述

第一行包含一个整数 m (1 <= m <= 10^6)。

接下来的 m 行中,每行都包含三个整数 ci, ei (1 <= ci,ei <= 10^6) 和 bi (bi∈{0,1}) ,表示 Colin 和 Eva 对于该物品的喜好值以及是否将该物品分配给 Colin 或 Eva。

输出描述

在每次操作之后,输出一行:

  • 如果当前分配方式是 “EF”,则输出 “EF”;

  • 否则如果当前分配方式是 “EFX”,则输出 “EFX”;

  • 否则如果当前分配方式是 “EF1”,则输出 “EF1”;

  • 否则输出 “E”。

示例1

输入

5
5 2 0
5 2 1
2 2 0
9 2 1
9 2 1

输出

EFX
EF
EFX
EF1
E
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考 程序设计竞赛相关代码、设计文档、使用说明,供学习参考

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值