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

news2025/1/9 1:05:38

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

参考资料

知乎:第五届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”。

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

参考代码c++

#include <iostream>
#include <algorithm>
using namespace std;

signed main() {
//	加快输入输出速度,常用方法
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr);

	string s;
	cin >> s;
	reverse(s.begin(), s.end());
	s += "00";
	int cnt = 0, n = s.size();
	for (int i = 0; i < n; i++) {
		if (s[i] == '1') {
			if (i == n - 1 || s[i + 1] == '0')
				cnt++;
			else {
				while (i < n - 1 && s[i] == '1')
					s[i++] = '0';
				s[i] = '1';
				i--;
				cnt++;
			}
		}
	}
	cout << cnt << endl;
	return 0;
}

C 家庭作业

题目大意:

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

解题思路:

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

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

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

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

参考代码c++

#include <iostream>
#include <vector>
using namespace std;
#define endl '\n'
#define int ll
typedef long long ll;

signed main() {
//	加快输入输出速度,常用方法
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr);

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

D 无嫉妒

题目大意:

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

解题思路:

题目很长,但算是签到题(网上的大佬说的)。

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

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

使用pair处理会方便许多。

要注意优化,不然可能过不去。

参考代码c++

使用C++(g++ 7.5.0)提交代码,C++(clang++ 11.0.1)可能会有问题

#include <iostream>
using namespace std;
// 这行要写,不然可能过不去
#define endl '\n'
#define int ll
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll, ll>PII;

signed main() {
//	加快输入输出速度,常用方法
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr);

	//max表示对面认为我的价值最高的物品,min表示对面认为我的价值最低的物品
	int n, a, b, c, maxx = 0, maxy = 0, minx = 1e9, miny = 1e9;
	//first表示自己拥有的自己眼里物品总价值,second表示自己拥有的对面眼里物品总价值
	PII x, y;
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> a >> b >> c;
		if (c == 0) { // 物品属于第一个人
			x.first += a;
			x.second += b;
			maxx = max(maxx, b);
			minx = min(minx, b);
		} else { // 物品属于第二个人
			y.first += b;
			y.second += a;
			maxy = max(maxy, a);
			miny = min(miny, a);
		}
//		对应四种情况
		if (x.first >= y.second && y.first >= x.second) {
			cout << "EF" << endl;
		} else if (x.first >= y.second - miny && y.first >= x.second - minx) {
			cout << "EFX" << endl;
		} else if (x.first >= y.second - maxy && y.first >= x.second - maxx) {
			cout << "EF1" << endl;
		} else
			cout << "E" << endl;
	}
	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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/605686.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++11/C++14中constexpr的使用

常量表达式(const expression)是指值不会改变并且在编译过程中就能得到计算结果的表达式。字面值属于常量表达式&#xff0c;用常量表达式初始化的const对象也是常量表达式。 只要有可能使用constexpr&#xff0c;就使用它。 C11中constexpr的使用&#xff1a; constexpr是C11中…

MKS SERVO4257D 闭环步进电机_系列7 MODBUS-RTU通讯示例

第1部分 产品介绍 MKS SERVO 28D/35D/42D/57D 系列闭环步进电机是创客基地为满足市场需求而自主研发的一款产品。具备脉冲接口和RS485/CAN串行接口&#xff0c;支持MODBUS-RTU通讯协议&#xff0c;内置高效FOC矢量算法&#xff0c;采用高精度编码器&#xff0c;通过位置反馈&a…

论坛项目学习记录【预备篇2】

论坛项目学习记录【预备篇2】 1. 什么是依赖注入2. 怎么使用依赖注入依赖注入注意事项 3.组件扫描情况下依赖注入的实现4.Resource注解的使用与Autowired的区别5.SpringMvcSpringMvc执行流程 1. 什么是依赖注入 就是在Spring容器内容将各个对象的依赖关系建立好的操作&#xf…

持续集成和持续交付:构建高效的软件交付流水线

在现代软件开发中&#xff0c;持续集成&#xff08;Continuous Integration&#xff09;和持续交付&#xff08;Continuous Delivery&#xff09;已成为构建高效、可靠软件交付流水线的关键实践。通过自动化和频繁地集成代码、构建、测试和部署&#xff0c;团队能够更快地交付高…

Unity--使用Cinemachine Confiner设置摄像机边界

使用Cinemachine Confiner设置摄像机边界 前提提要&#xff1a;在做这个功能前需要&#xff1a; ​ main camera ​ 另外一个相机 思路&#xff1a;创建一个对象绑定Polygon Collider2D 边界。然后在另外一个相机Cinemachine Confiner上绑定他 ​ 绑定边界 记得点这个&#…

2023年京东618全品类预售数据查询

这一期主要分享今年618京东数码产品的预售数据&#xff0c;包括笔记本电脑、投影机、微单相机三大品类。 -笔记本电脑- 今年618&#xff0c;笔记本电脑在京东累计预售量达到73万件&#xff0c;预售额达到41亿元。预售期间&#xff0c;微单相机品类均价在5661元左右。期间&#…

软件测试实验:链接测试

目录 前言实验目的实验环境实验内容实验步骤实验过程总结 前言 本实验的目的是学习和掌握软件测试中的链接测试方法和技巧。链接测试是指对Web应用系统中的各种链接进行检查和验证&#xff0c;以确保它们能正确地指向预期的目标&#xff0c;不出现错误链接、空链接、死链接或孤…

简单尝试:ChatGLM-6B + Stable diffusion管道连接

核心思想是&#xff1a; 1. 抛去算法设计方面&#xff0c;仅从工程角度考虑的话&#xff0c;Stable diffusion的潜力挖掘几乎完全受输入文字影响。 2. BLIP2所代表的一类多模态模型走的路线是"扩展赋能LLM模型"&#xff0c;思路简单清晰&#xff0c;收益明显。LLM …

电池状态估计 | Matlab实现利用卡尔曼滤波器估计电池充电状态

文章目录 效果一览文章概述研究内容程序设计参考资料效果一览 文章概述 电池状态估计 | Matlab实现利用卡尔曼滤波器估计电池充电状态 研究内容 目前,常用的电池模型有:数

外包干了5年,女朋友嫌弃我,跑了。。。

先说一下自己的情况。大专生&#xff0c;17年通过校招进入湖南某软件公司&#xff0c;干了接近5年的测试&#xff0c;今年年上旬&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落&#xff01;而我已经在一个企业干了5年&#xff0c;…

一文带你了解MySQL之约束

在SQL标准中&#xff0c;一共规定了6种不同的约束&#xff0c;包括非空约束&#xff0c;唯一约束和检查约束等&#xff0c;而在MySQL中是不支持检查约束的&#xff0c;所以这篇文章先对其余5种约束做一个详解和练习。 文章目录 1. 约束的概念2. 约束的分类3. 非空约束4. 唯一约…

大数据:pyspark模块,spark core的RDD,RDD是弹性分布式数据抽象对象,RDD五大特性,wordcount案例展示RDD

大数据&#xff1a;pyspark模块 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;oracle&#xff0c;尤其sql…

English Learning - L3 作业打卡 Lesson4 Day29 2023.6.2 周五

English Learning - L3 作业打卡 Lesson4 Day29 2023.6.2 周五 引言&#x1f349;句1: I once made a big mistake at the office and felt foolish.成分划分弱读连读爆破语调 &#x1f349;句2: I had egg on my face.成分划分弱读语调 &#x1f349;句3: Over the weekend, m…

Java企业级信息系统开发学习笔记13 Spring Boot(使用maven方式构建Spring Boot项目)

文章目录 一、学习目标二、Spring Boot框架概述三、使用maven方式构建Spring Boot项目&#xff08;一&#xff09;创建Maven项目&#xff08;二&#xff09;添加依赖&#xff08;三&#xff09;创建入口类&#xff08;四&#xff09;创建控制器&#xff08;五&#xff09;运行入…

防火墙之服务器负载均衡

防火墙之服务器负载均衡 原理概述&#xff1a; 防火墙&#xff08;英语&#xff1a;Firewall&#xff09;技术是通过有机结合各类用于安全管理与筛选的软件和硬件设备&#xff0c;帮助计算机网络于其内、外网之间构建一道相对隔绝的保护屏障&#xff0c;以保护用户资料与信息安…

C语言---操作符详解

1、操作符分类 算术操作符 移位操作符 位操作符 赋值操作符 单目操作符 关系操作符 逻辑操作符 条件操作符 逗号操作符 下标引用、函数调用和结构成员。 2、算数操作符 - * / %// 7 / 2 ----->3 // 7 % 2 ----->1//那如果想要打印…

Java程序设计入门教程--类的创建过程

构造方法 在Java的每个类中都有一种特殊的成员方法&#xff0c;它的方法名和类名是一致的。在创建对象时&#xff0c;调用这种特殊方法对成员变量进行初始化&#xff0c;这种方法称为构造方法。 注意 创建构造方法与创建成员方法的格式相同&#xff0c;但要注意以下几点&#…

3GPP R16 HST

3GPP R16高铁场景为了能够支持最高3.6GHz载波频率以及最高500km/h的速度&#xff0c;提出了增强RRM要求和终端解调能力要求。 在增强RRM要求的维度&#xff0c;对intra-RAT和inter-RAT测量提出了新的要求。其中&#xff0c;intra-RAT测量包括NR小区重选要求、NR小区识别要求、波…

大数据:hadoop spark,spark特点,功能,架构,模块,角色

大数据&#xff1a;hadoop spark 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;oracle&#xff0c;尤其sq…

把玩数据在内存中的存储

前言&#xff1a;时光如梭&#x1f4a6;&#xff0c;今天到了C语言进阶啦&#x1f60e;&#xff0c;基础知识我们已经有了初步认识&#xff0c; 是时候该拔高拔高自己了&#x1f63c;。 目标&#xff1a;掌握浮点数在内存的存储&#xff0c;整形在内存的存储。 鸡汤&#xff1a…