IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【Codeforces Round #813 (Div. 2)(A~C)】 -> 正文阅读

[C++知识库]【Codeforces Round #813 (Div. 2)(A~C)】

更好的阅读体验 \color{red}{更好的阅读体验} 更好的阅读体验


A. Wonderful Permutation


题目大意

Origional Link

  • 给定长度为 n n n 的数组 a a a,元素互不相同
  • 每次可选择 a i , a j a_i,a_j ai?,aj? 进行交换
  • 求使得长度为 k k k 的子序列之和达到最小的交换次数

思想

  • 对于子序列的和最小,应遵循最小排列
  • 即判断原序列中,前 k k k 个元素,有多少满足 a i ≤ k a_i\le k ai?k,满足该条件则不需要交换,否则需要交换

代码

#include <bits/stdc++.h>
using namespace std;

#define re register

const int N = 1e6 + 3;

int a[N];

void solve(){
	
	int n, k;
	
	cin >> n >> k;
	
	for(re int i = 1; i <= n; i ++) cin >> a[i];
	
	int cnt = 0;
	
	for(re int i = 1; i <= k; i ++) if(a[i] > k) cnt ++;
	
	cout << cnt << endl;
	
}

int main(){
	
//	solve();
	
	int _;
	cin >> _;
	
	while(_ --){
		solve();
	}
	
	return 0;
	
}

B. Woeful Permutation


题目大意

Origional Link

  • 给定元素为 1 ~ n 1\sim n 1n 的数组 a a a
  • 求使得 l c m ( 1 , a 1 ) + l c m ( 2 , a 2 ) + … l c m ( i , a i ) lcm(1,a_1)+lcm(2,a_2)+\dots lcm(i,a_i) lcm(1,a1?)+lcm(2,a2?)+lcm(i,ai?) 最大的子序列

思想

  • 已知 l c m ( a , b ) = a × b g c d ( a , b ) lcm(a,b) = \frac{a\times b}{gcd(a,b)} lcm(a,b)=gcd(a,b)a×b?
  • 若使得 l c m ( a , b ) lcm(a,b) lcm(a,b) 最大,则应尽可能使得 g c d ( a , b ) = 1 gcd(a,b) = 1 gcd(a,b)=1
  • 对于序列中的元素 a i = i a_i=i ai?=i
  • 则有 g c d ( i , a i + 1 ) = 1 gcd(i,a_i + 1) = 1 gcd(i,ai?+1)=1
  • a i = i + 1 , a i + 1 = i a_i = i +1, a_{i + 1} = i ai?=i+1,ai+1?=i 时,满足题意
  • 即:
    • n n n 为偶数时,遵循排列: 2 , 1 , 4 , 3 , 6 , 5 , … , n , n ? 1 2,1,4,3,6,5,\dots ,n,n-1 2,1,4,3,6,5,,n,n?1
    • n n n 为奇数时,遵循排列: 1 , 3 , 2 , 5 , 4 , 7 , 6 … , n , n ? 1 1,3,2,5,4,7,6\dots ,n,n-1 1,3,2,5,4,7,6,n,n?1

代码

#include <bits/stdc++.h>
using namespace std;

#define re register

void solve(){
	
	int n;
	
	cin >> n;
	
	if(n % 2 == 0){
		for(re int i = 2; i <= n; i += 2) cout << i << " " << i - 1 << " ";
	}
	else{
		cout << 1 << " ";
		for(re int i = 3; i <= n; i += 2) cout << i << " " << i - 1 << " ";
	}
	
	cout << endl;

}

int main(){
	
//	solve();
	
	int _;
	cin >> _;
	
	while(_ --){
		solve();
	}
	
	return 0;
	
}

C. Sort Zero


题目大意

Origional Link

  • 给定长度为 n n n 的数组 a a a
  • 每次操作,可以将所有 a i = x a_i = x ai?=x 的元素操作变为 a i = 0 a_i = 0 ai?=0
  • 求最少操作多少次,可以使得原数组元素不严格单调递增

思想

  • int a[N]存储数组元素,set<int> b存储当前枚举到i之前,需要将 a i a_i ai? 变为 0 0 0 x x x
  • i = 2开始枚举a[i]
    • 先判断a[i]是否在b中,若存在,则更新a[i] = 0
    • a[i - 1] > a[i],说明需要将a[i - 1]更新,将b.insert(a[i - 1]),且要使得i之前所有的a[j] == a[i - 1]的元素更新为 0 0 0,且在更新时,要将a[j] != 0的元素也加入b
  • 由于我们按顺序枚举,故在i之前的序列一定满足不严格单调递增,在枚举结束之后,b中元素个数即为操作次数

代码

#include <bits/stdc++.h>
using namespace std;

#define re register

const int N = 1e6 + 3;

int a[N];

set<int> b;

void solve(){
	
	int n;
	cin >> n;
	
	for(re int i = 1; i <= n; i ++) cin >> a[i];
	
	for(re int i = 2; i <= n; i ++){
		
		if(b.count(a[i]) > 0) a[i] = 0;

		if(a[i - 1] > a[i]){
			b.insert(a[i - 1]);
			a[i - 1] = 0;
			for(re int j = i - 1; a[j] != 0 && j >= 1; j --){
				b.insert(a[j]);
				a[j] = 0;
			}
		}
		
	}
	
	cout << b.size() << endl;
	
	b.clear();

}

int main(){
	
//	solve();
	
	int _;
	cin >> _;
	
	while(_ --){
		solve();
	}
	
	return 0;
	
}

后记

  • A A A 没有什么难度,但是做的太急(permutation是无重复元素的排列数组),没有思考好规律
  • B B B 真的是 W A \color{red}{WA} WA 到飞起,怎么会有我这种笨比推出来 g c d ( i , a i + 1 ) = 1 gcd(i,a_i + 1) = 1 gcd(i,ai?+1)=1 规律还解不出来的人,建议自己remake
  • C C C 一开始思路很乱,后来发现模拟就好了,写完直接交一发就过,没什么算法难度
  • 手速场狂 W A \color{red}{WA} WA两道 A , B A,B A,B nt题的我真是没救了,前几场着实给我打破防了,这回还好最后没放弃,继续努力吧
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-08-19 18:45:50  更:2022-08-19 18:49:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 10:05:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码