【Codeforces Round #835 (Div. 4)】A——G题解

news2024/12/23 6:24:20

在这里插入图片描述

文章目录

    • A Medium Number
      • 题意
      • 思路
      • 代码
    • B Atilla's Favorite Problem
      • 题意
      • 思路
      • 代码
    • C Advantage
      • 题意
      • 思路
      • 代码
    • D Challenging Valleys
      • 题意
      • 思路
      • 代码
    • E Binary Inversions
      • 题意
      • 思路
      • 代码
    • F Quests
      • 题意
      • 思路
      • 代码
    • G SlavicG's Favorite Problem
      • 题意
      • 思路
      • 代码

A Medium Number

题意

三个数,输出中位数。

思路

排序

input

9
5 2 6
14 3 4
20 2 1
1 2 3
11 19 12
10 8 20
6 20 3
4 1 3
19 8 4

output

5
4
2
2
12
10
6
3
8

代码

int n, m;
int a[N];
 
void solve() {
	n = 3;
	for (int i = 0; i < 3; i++) cin >> a[i];
	sort(a, a + 3);
	cout << a[1] << endl;
}

B Atilla’s Favorite Problem

题意

找到最大字符,对应如下输出:‘a’ -> 1;‘b’ -> 2;…;‘z’ -> 26;

思路

维护最大值

input

5
1
a
4
down
10
codeforces
3
bcf
5
zzzzz

output

1
23
19
6
26

代码

int n, m;
int a[N];
 
void solve() {
	int n; cin >> n;
	string s; cin >> s;
	int mx = -1;
	for (auto c: s) {
		mx = max(mx, (int)(c - 'a') + 1);
	}
	cout << mx << endl;
}

C Advantage

题意

输出每个数 - 除自己之外的最大值。

思路

维护最大和次大,排序。

input

5
4
4 7 3 5
2
1 2
5
1 2 3 4 5
3
4 9 4
4
4 4 4 4

output

-3 2 -4 -2
-1 1
-4 -3 -2 -1 1
-5 5 -5
0 0 0 0

代码

int n, m;
int a[N], b[N];
 
void solve() {
	int n; cin >> n;
	int x = -1, mx = -1;
	rep (i, 1, n) cin >> a[i], b[i] = a[i], x = max(x, a[i]);
	sort(b + 1, b + 1 + n);
	mx = b[n - 1];
	rep (i, 1, n) if(a[i] == x) cout << x - mx << ' '; else cout << a[i] - x << ' '; cout << endl;
}

D Challenging Valleys

题意

问是否仅存在一个子数组,满足:

  • a l = a l + 1 = . . . = a r a_l=a_{l+1}=...=a_r al=al+1=...=ar
  • l = 0 l=0 l=0 或者 a l − 1 > a l a_{l-1}>a_l al1>al
  • r = n − 1 r=n-1 r=n1 或者 a r + 1 > a r a_{r+1}>a_r ar+1>ar

思路

如上条件,即一个 V 字型的尖尖,或者 _/ 的平段,或者 \_ 的平段。

统计这三种的个数,看是否最终为 1 即可。

便于统计,我们记数组 1 − n 1-n 1n,初始化 a [ 0 ] = a [ n + 1 ] = I N F a[0] = a[n + 1] = INF a[0]=a[n+1]=INF

双指针,左端点固定,去移动右端点,直到这一段相等结束(条件1),判断上述 V 字型条件(条件2,3)即可。

input

6
7
3 2 2 1 2 2 3
11
1 1 1 2 3 3 4 5 6 6 6
7
1 2 3 4 3 2 1
7
9 7 4 6 9 9 10
1
1000000000
8
9 4 4 5 9 4 9 10

output

YES
YES
NO
YES
YES
NO

代码

int n, m;
int a[N];
void solve() {
	cin >> n;
	rep (i, 1, n) cin >> a[i];
	int cnt = 0;
	a[0] = a[n + 1] = mod;
	int l = 1;
	for (int i = 2; i <= n + 1; i++) {
		while (i <= n && a[i] == a[l]) i++;
		if (a[l] < a[l - 1] && a[i - 1] < a[i]) cnt++;
		l = i;
	}
	if (cnt == 1 || n == 1) cout << "YES" << endl;
	else cout << "NO" << endl;
}

E Binary Inversions

题意

给你01字符串,问至多一次,反转一个字符(0-1,1-0),使得逆序对最大,输出最大个数。

思路

三种情况:

  • 0次操作:

    • 直接统计逆序数即可,维护后缀0的数量,一次遍历,累加上位1的0的贡献。
  • 1次操作:

    • 从前往后第一个0改1
    • 从后往前第一个1改0

input

5
4
1 0 1 0
6
0 1 0 0 1 0
2
0 0
8
1 0 1 1 0 0 0 1
3
1 1 1

output

3
7
1
13
2

代码

有点烂,不想改了,思路够清晰。

int n, m;
int a[N];
 
void solve() {
	cin >> n;
	
	int res = 0;
	
	int zero = 0, one = 0;
	for (int i = 1; i <= n; i++) cin >> a[i], zero += 1 - a[i], one += a[i];
	
	int xx = zero;
	for (int i = 1; i <= n; i++) if (a[i] == 1) res += xx; else xx -= 1;
	
	int idx1 = 1;
	while (idx1 <= n && a[idx1] == 1) idx1++;
	if(idx1 <= n && a[idx1] == 0) a[idx1] = 1, zero -= 1, one += 1;
	int t = zero, res1 = 0;
	for (int j = 1; j <= n; j++) if (a[j] == 1) res1 += t; else t -= 1;
	if(idx1 <= n && a[idx1] == 1) a[idx1] = 0, zero += 1, one -= 1;
	
	int res2 = 0, idx = n;
	while (idx >= 1 && a[idx] == 0) idx--;
	if (idx >= 1 && a[idx] == 1) one -= 1, zero += 1, a[idx] = 0;
	t = zero;
	for (int j = 1; j <= n; j++) if (a[j] == 1) res2 += t; else t -= 1;
 
	cout << max({res, res1, res2}) << endl;
 

F Quests

题意

给定 n , c , d n,c,d ncd,表示任务数组大小 n , d n,d nd 天要赚至少 c c c 元。每次工作了任务 i i i,那么接下来 k k k 天,这个任务不可再做。问 k k k 最大能是多少。

思路

最小的最大 :二分答案

贪心的从大到小排序,维护前缀和。贪心的做任务获利高的任务,但每隔 k k k 天才做下一次,所以一个周期做 k + 1 k+1 k+1 个任务( d d d 很大则考虑这种写法,否则直接暴力 d d d 天每次循环加上对应天下做的任务即可)。每次 c h e c k check check 去判断,当前每个任务重做时间隔 k k k 天,且在 d d d 天内,能否获利 c c c 元。

input

6
2 5 4
1 2
2 20 10
100 10
3 100 3
7 2 6
4 20 3
4 5 6 7
4 100000000000 2022
8217734 927368 26389746 627896974
2 20 4
5 1

output

2
Infinity
Impossible
1
12
0

代码

  • c h e c k 1 check1 check1: 暴力加,循环节控制当天做的任务 i d id id
  • c h e c k check check d d d 如果很大,则按周期加。
int n, m, c, d;
int a[N], s[N];
 
bool check1(int x) {
	int res = 0;
	int now = 1;
	for (int i = 1; i <= d; i++) {
		if (now <= n) {
			res += a[now];
			now++;
		} 
		if (i % (x + 1) == 0) {
			now = 1;
		}
	}
	return res >= c;
}
 
bool check(int x) {
	x += 1;
	int pre = 0;
	if (x > n) pre = s[n];
	else pre = s[x];
	int now = 0, res = 0;
	while (now + x <= d) {
		res += pre;
		now += x;
		if (res >= c) return true;
	}
	for (int i = 1; i <= d - now && i <= n; i++) res += a[i];
	return res >= c;
}
 
void solve() {
	cin >> n >> c >> d;
	for (int i = 1; i <= n; i++) cin >> a[i];
	sort(a + 1, a + 1 + n, [=](int i, int j){ return i > j; });
	int z = 0; for (int i = 1; i <= min(n, d); i++) z += a[i];
	if (z >= c) { cout << "Infinity" << endl; return ; }
	if (d * a[1] < c) { cout << "Impossible" << endl; return ; }
	for (int i = 1; i <= n; i++) s[i] = s[i - 1] + a[i];
	int l = 0, r = 2e18;
	while (l < r) {
		int mid = (l + (r - l + 1) / 2);
		if (check(mid)) l = mid;
		else r = mid - 1;
	}
	cout << r << endl;
}

G SlavicG’s Favorite Problem

题意

n n n 个点, n − 1 n-1 n1条边,边权 w i w_i wi。(每走一边,需要异或当前边权)。给定 a , b a,b a,b,问从 a a a 出发,能否走往 b b b 点。条件是仅当走到 b b b 时,当前异或值为 0 0 0。并且,可以允许在路途中进行一次跳跃,即直接跳到任意除 b b b 外的一点。

注意的是,但凡走到了 b b b 就需要截止了(如果不为0,就走不到)。这意味着,从 a a a 开始走,要想去往 b b b 的子树下,仅能使用一次跳跃过去,而不能走过去。

思路

分别以 a , b a,b a,b 为根节点,计算所有点到根节点的一个前缀异或值,记 f a , f b fa,fb fa,fb 数组。(注意,这里 a a a 为根节点的话,不能去往 b b b 的子树)

f a fa fa 数组,将所有可达点( f a [ i ] ! = − 1 fa[i] != -1 fa[i]!=1,包括 a a a 本身【因为如果 f b [ a ] = 0 fb[a]=0 fb[a]=0 是直接可达的】,默认 f a [ a ] = 0 fa[a] = 0 fa[a]=0)统计进 m a p map map 中。

f b fb fb 数组,遍历所有点,判断如果当前点不是 b b b 本身,且 m a p map map 中存在 f b [ i ] fb[i] fb[i] ,那么说明至多一次跳跃,可以让跳跃前异或值等于跳跃后异或值,走完到 b b b 即异或为 0 0 0

input

3
5 1 4
1 3 1
2 3 2
4 3 3
3 5 1
2 1 2
1 2 2
6 2 3
1 2 1
2 3 1
3 4 1
4 5 3
5 6 5

output

YES
NO
YES

代码

int h[N], w[M], e[M], ne[M], idx; 
void add(int a, int b, int c = 1) { 
	e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx++; 
} 
int n, a, b;
int fa[N], fb[N];
int root;
void dfs(int u, int f, int v) {
	if(root == a) fa[u] = v;
	else if(root == b) fb[u] = v;
	for (int i = h[u]; ~i; i = ne[i]) {
		int j = e[i];
		if (j == f) continue; 
		if (root == a && j == b) continue; 
		dfs(j, u, v ^ w[i]);
	}
}
 
void solve() {
	memset(fa, -1, sizeof fa);
	memset(fb, -1, sizeof fb);
	memset(h, -1, sizeof h);
	cin >> n >> a >> b;
	for (int i = 0; i < n - 1;i ++) {
		int u, v, x; cin >> u >> v >> x;
		add(u, v, x), add(v, u, x);
	}
	root = a; fa[root] = 0;
	dfs(a, -1, 0);
	root = b; fb[root] = 0;
	dfs(b, -1, 0);
	map<int, int> mp;
	bool f = false;
	for (int i = 1; i <= n; i++) {
		if (i == b) continue; // 删掉也行吧,fa[b] == -1;
		else if(fa[i] != -1) mp[fa[i]] = 1;
	}
	for (int i = 1; i <= n; i++) {
		if (i == b) continue;
		else if (mp.count(fb[i])) f = true;
	}
	cout << (f ? "YES" : "NO") << endl;
}

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

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

相关文章

窗口-视口转换(详细)

在QPainter中&#xff0c;绘制图像使用逻辑坐标绘制&#xff0c;然后再转化为绘图设备的物理坐标。 窗口&#xff08;window&#xff09;&#xff1a;表示逻辑坐标下的相同矩形视口&#xff08;viewport&#xff09;&#xff1a;表示物理坐标下的指定的一个任意矩形默认情况&am…

中国互联网大会天翼云展区大揭秘!

11月15日&#xff0c;由工业和信息化部、深圳市人民政府主办&#xff0c;中国互联网协会、广东省通信管理局、深圳市工业和信息化局等单位承办的2022&#xff08;第二十一届&#xff09;中国互联网大会在深圳开幕。本届大会以“发展数字经济 促进数字文明”为主题&#xff0c;聚…

单商户商城系统功能拆解34—应用中心—分销应用

单商户商城系统&#xff0c;也称为B2C自营电商模式单店商城系统。可以快速帮助个人、机构和企业搭建自己的私域交易线上商城。 单商户商城系统完美契合私域流量变现闭环交易使用。通常拥有丰富的营销玩法&#xff0c;例如拼团&#xff0c;秒杀&#xff0c;砍价&#xff0c;包邮…

在IDEA中搭建Spring5.2.x版本源码(~附带完整过程和图示~)

1.开发环境 JDK8IntelliJ IDEA 2019.1.4 gradle 5.6.4git 2.33.0 2.操作步骤 下载并安装git 进入https://git-scm.com/downloads&#xff0c;下载对应操作系统的git版本一直点击next安装即可记得配置环境变量 获取Spring源码 使用clone的方式将源码拉取到本地&#xff0c;方便…

Java递归查询树形结构(详解)

一.数据准备 数据库表结构如下所示&#xff0c; INSERT INTO jg_user.com_type(type_id, parent_id, type_name) VALUES (1, 0, 合伙企业); INSERT INTO jg_user.com_type(type_id, parent_id, type_name) VALUES (2, 0, 有限公司); INSERT INTO jg_user.com_type(type_id, p…

力扣(LeetCode)878. 第 N 个神奇数字(C++)

二分查找数论 数论知识——辗转相除法、容斥原理。 辗转相除求最大公约数&#xff0c;两数相乘除以最大公约数&#xff0c;就是最小公倍数。 容斥原理求最多不重复元素&#xff0c;最大不重复面积。 <小学数奥> 从数据范围里&#xff0c;用容斥原理找 a/ba/ba/b 的倍数个…

Pytorch 下 TensorboardX 使用

这里引用一下在其他地方看到的一些话&#xff1a; tensorboard做为Tensorflow中强大的可视化工具&#xff0c;已经被普遍使用。 但针对其余框架&#xff0c;例如Pytorch&#xff0c;以前一直没有这么好的可视化工具可用&#xff0c;PyTorch框架自己的可视化工具是Visdom&…

实验九 数据微积分与方程数值求解(matlab)

实验九 数据微积分与方程数值求解 1.1实验目的 1.2实验内容 1.3流程图 1.4程序清单 1.5运行结果及分析 1.6实验的收获与体会 1.1实验目的 1&#xff0c;掌握求数值导数和数值积分的方法&#xff1b; 2&#xff0c;掌握代数方程数组求解的方法&#xff1b; 3&a…

【Mysql】Centos 7.6安装Mysql8

这里centos为阿里云默认镜像。 一、卸载历史历史版本 1、检查是否有服务启动 # service mysqld status 2、停止mysql服务 # service mysqld stop 3、查看mysql历史安装组件 # rpm -qa|grep mysqlmysql-libs-5.1.71-1.el6.x86_64 4、卸载组件 # rpm -e --nodeps mysql…

2022世界VR产业大会圆满收官,酷雷曼惊艳亮相!

11月14日&#xff0c;由工业和信息化部、江西省人民政府联合主办的全球VR领域规模最大、规格最高、影响最广的年度盛会——2022世界VR产业大会在江西南昌圆满落下帷幕。 本次大会得到了党中央、国务院的高度重视&#xff0c;国务委员王勇出席大会开幕式并讲话&#xff1b;大会邀…

【转】DNS隧道检测特征

原文链接&#xff1a;DNS隧道检测特征总结 - 知乎 一、摘要 企业内网环境中&#xff0c;DNS协议是必不可少的网络通信协议之一&#xff0c;为了访问互联网和内网资源&#xff0c;DNS提供域名解析服务&#xff0c;将域名和IP地址进行转换。网络设备和边界防护设备在一般的情况…

C++:内存管理:C++内存管理详解

C语言内存管理是指&#xff1a;对系统的分配、创建、使用这一系列操作。在内存管理中&#xff0c;由于是操作系统内存&#xff0c;使用不当会造成很麻烦的后果。本文将从系统内存的分配、创建出发&#xff0c;并且结合例子来说明内存管理不当会造成的结果以及解决方案。 一&am…

【Spring】Spring AOP的实现原理

目录 什么是AOP AOP的作用 AOP的优点 AOP框架 Spring AOP AspectJ 术语 1.Target ——目标类 2.Joinpoint ——连接点 3.Pointcut——切入点 4.Advice——通知/增强 5.Weaving——植入 6.Proxy——代理类 7.Aspect——切面 底层逻辑 开发流程 1.导入依…

八、手把手教你搭建SpringCloudAlibaba之Sentinel服务降级之慢调用

SpringCloud Alibaba全集文章目录&#xff1a; 零、手把手教你搭建SpringCloudAlibaba项目 一、手把手教你搭建SpringCloud Alibaba之生产者与消费者 二、手把手教你搭建SpringCloudAlibaba之Nacos服务注册中心 三、手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心 …

贪心算法应用

1. 算法思想 贪心算法一般分为如下四步&#xff1a; 将问题分解为若干个子问题找出适合的贪心策略求解每一个子问题的最优解将局部最优解堆叠成全局最优解 即选择每一阶段的局部最优&#xff0c;从而达到全局最优。 2. 最大自序和 题目描述 题目链接 给你一个整数数组 n…

用Servlet 编写hello world

第一次接触 Servlet&#xff0c;使用 Servlet 编写代码并配合 Tomcat 在浏览器中展示代码效果&#xff0c;也算是自己这么长时间学习java的一次飞升吧。 本文总结了六步使用 Servlet 编写 helloworld步骤&#xff0c;希望给初学Servlet的同学一些帮助。 0、准备工作 1&#xff…

Python 随机函数random详解

介绍这7个随机数的方法应用&#xff1a; 1、random.random&#xff08;&#xff09;查看源码 说明&#xff1a;用于生成一个0到1的随机符点数: 0 < x < 1.0 import random for i in range(10):print(random.random()) 2、random.uniform&#xff08;&#xff09;查看源码…

深度学习(14)—— 关于Tensorboard

深度学习&#xff08;14&#xff09;—— 关于Tensorboard 文章目录深度学习&#xff08;14&#xff09;—— 关于Tensorboard前言1. “一参数一图”2.“多参数一图”3. “一栏一图”4. “一栏多图”在模型训练过程中loss和acc都会发生变化&#xff0c;常常需要记录这些值&…

Spring Security(2)

您好&#xff0c;我是湘王&#xff0c;这是我的CSDN博客&#xff0c;欢迎您来&#xff0c;欢迎您再来&#xff5e; 前面已经把需要的环境准备好了&#xff0c;包括数据库和SQL语句&#xff0c;现在再来写代码。至于安装MySQL什么的就跳过去了&#xff0c;娘度子里面一大把。 先…

保护Excel表格的4种常用方法

今天来说说&#xff0c;根据不同需求&#xff0c;我们可以给Excel表格设置保护的4种常用方法&#xff0c;记得保存收藏&#xff0c;总有一个适合你。 方法一&#xff1a; 如果不想Excel表格被他人随意打开&#xff0c;可以设置“打开密码”&#xff0c;这样只有输入设置的密码…