2023 OI 集训营普及组第四场题解

求余来喽

https://ac.nowcoder.com/acm/contest/65189/A

T1 求余来咯

考察枚举答案

由于 较小,所以我们考虑枚举所有可能的答案 ,对于每一个 来说,用所有数字都进行求余,得到求余的和,同时记录最小值。

时间复杂度

#include <bits/stdc++.h>
using namespace std;
int a, cnt[5005];
int main(){
	int n, minn = 1e9, ans, l, r;
	cin >> n >> l >> r;
	for(int i = 1; i <= n; i++){
		cin >> a;
		for(int j = l; j <= r; j++){
			cnt[j] += a % j;
		}
	}
	for(int i = l; i <= r; i++){
		if(cnt[i] < minn){
			minn = cnt[i];
			ans = i;
		}
	}
	cout << ans << endl;
}

T2 牛牛的乘法考验

假设 个零

对题意进行转化,得到我们最终输出的答案 满足: 的因子。

也就是说对于 Q 来说,一部分是由 贡献的,另一部分是由 贡献的,两个数字乘起来得到

所以考虑 的最大公因数,这个最大公因数就是 的贡献。那么剩余的因数需要 来贡献,所以用 除以这个最大公因数就知道 的值了。

#include <bits/stdc++.h>
using namespace std;
long long a, k;
int main(){
	int t;
	cin >> t;
	while(t--){
		cin >> a >> k;
		long long Q = 1;
		for(int i = 1; i <= k; i++){
			Q *= 10;
		}
		cout << now / __gcd(Q, a) << '\n';
	}
}

T3 二叉树

每次修改实际上只会修改沿着当前点向上的一条链,这是 的。 下面考虑如何判断能否形成回文:只需要判断其中数量为奇数的字符不超过 1 种即可。

于是做法为:

  • 初始先进行一遍树形 DP,求初始情况下到每个点上各个字母有几个,统计一个初始的答案并输出。
  • 之后对于每次修改,沿着当前修改点向上逐个修改字符数量,修改完成后检查节点的改变情况,对答案数量做增减。改到根节点后停止并输出。

T4 普通的构造

首先考虑共有几个位置对。显然有 对。其中应该一半逆序对,一半顺序对。可以求出来一共是多少逆序对/顺序对。

考虑希望字典序最小。不妨逐位考虑:

  • 第一位放 时,后面的所有位置一定比 大,一定提供的是顺序对。会提供 对。
  • 第二位放 时,后面的所有位置一定比 大,会提供 对。
  • 一直重复第 位放入 的策略,直到某个放进去会导致顺序对超过需要的位置。

下面讨论这个位置:假设这个位置需要提供 对顺序对,那么这个位置最小只能填入 。 先把这个数字填进去,接下来考虑剩余位置不能提供任何顺序对。将剩余数字倒序填入剩下位置即可。

全部评论

相关推荐

2025-12-29 22:36
武汉大学 Java
点赞 评论 收藏
分享
2025-11-21 03:09
已编辑
南昌大学 golang
bg普211本,走的golang后端方向。找实习经历:最近一个月投了一些日常,面了4场,都是一面挂。简历包装成分比较多,当时这个简历准备了两个星期,问AI解决什么问题用什么技术,跟其他技术对比优缺点在哪,等等。但是面试的时候一些基础的八股都答的模模糊糊,然后项目延伸的场景题一点不会。有点害怕面试,面前焦虑…本文可能带点碎碎念…省流就是因为每周面心态不行,不知道先学什么以及三天打鱼两天晒网…现在的主要问题,一个是只能依靠即时满足无法撑过枯燥的学习,另一个是难以调整心态,面试焦虑。个人背景:主包其实本来是大一开始学后端的,但是当时不知道合适的学习方法(学习路线和借助AI),也社恐不太敢问学长,走了很多弯路,也没有花很多时间在后端上面(按兴趣学的只有大二上学期写了opencamp的rustlings和learning-cxx,还有玩steam的图灵完备,剩余时间比较摆烂)。结果就是现在这鬼样子,只会写crud,差不多就是会gin&nbsp;gorm基础,会写注册登录和简单业务接口,写过几种项目结构和设计模式。缺乏自己延展的能力。计算机基础:也相当差,之前大二学的计网全忘光了,操作系统60飘过。虽然大一的时候打算法竞赛(也没什么成绩就是,省二等奖收集者),但到现在一年半没碰了,就只有dfs,并查集啥的一些很基础的题目随便写,hot100链表因为竞赛没练过相当不熟练。大二下的时候,数据库课看八股,又困又累,什么都没看进去,后面自然又是全忘光了。现在我虽然有了个概览,知道后端除了crud有缓存、微服务、分布式、消息队列等等东西,知道后端架构设计是要做权衡,性能、一致性、容灾,需要通过实验测出具体的数据来做决策,但是具体的方案不会,看基础知识是真看不进去。现在的主要问题,一个是只能依靠即时满足无法撑过枯燥的学习,另一个是难以调整心态。我高中以前一直是优等生,能够享受大部分题目都会的快感,能明确地有信心自己能做出来,解题过程需要进行推理,并且做完立刻就能得到正确反馈,其中的失败调整过程长度也在可接受范围内。(喜欢写rustlings一类的语言lab和玩《图灵完备》大概也是因为这个吧…)而现在的情景相当于我成了高三但是基础知识基本不会的状态,比我当年(会基础知识只是差做题)差多了。在这种情况下去面试也是相当痛苦,因为面试是不知道范围的。每次准备都不知道先看什么,学也学不进去。明明知道面试只是为了了解真实会问什么,但是还是很焦虑,拧巴心态。学长说去投简历面试实践是为了了解自己在哪里,别人在哪里,市场在哪里,但是我似乎还没有找到收敛的下限,只是一直失败…但是我也不能确定不面试就能学进去啊,因为我大二暑假是真的一点代码都不想碰,相当烦躁,八股也不想看。现在甚至连稍微花点时间的算法题(不能即时反馈的)都不想写了。还在纠结要不要整块时间搓项目压测试试,感觉会非常花时间。可能我项目管理也是一坨。
圆规学java:27届不着急,边投边学,克服恐惧感,你现在不敢面试,你为什么认为你暑期就勇敢了,你现在的进度其实还很早,我当时大三下才开始实习,我也很焦虑着急。永远没有准备好的时候,当下努力就是最好的加油!
点赞 评论 收藏
分享
评论
6
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务