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 #808 (Div. 2)(ABC) -> 正文阅读

[C++知识库]Codeforces Round #808 (Div. 2)(ABC)

目录

A. Difference Operations

题目链接:

题面:?编辑

题意:?

思路:

代码:

B. Difference of GCDs

题目链接:

题面:

题意:

思路:

代码:

C. Doremy's IQ

题目链接:

题面:

题意:?

思路:

代码:


A. Difference Operations

题目链接:

Problem - A - Codeforces

题面:

?

题意:?

给定n个数,可以选择一个位置(2到n)使ai变成ai-a(i-1),问能否把2到n的位置上的数都变成0

思路:

如果后面的每个数都是第一个的倍数,那么就可以变为0

代码:

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

int arr[105];

int main(){
	int t;
	cin >> t;
	while(t--){
		int n;
		cin >> n;
		for(int i = 0; i < n; i++){
			cin >> arr[i]; 
		}
		bool f = 0;
		for(int i = 1; i < n; i++){
			if(arr[i] % arr[0] != 0){
				f = 1;
				break;
			}
		}
		if(f){
			cout << "NO" << endl;
		}else{
			cout << "YES" << endl;
		}
	}
	return 0;
} 

B. Difference of GCDs

题目链接:

Problem - B - Codeforces

题面:

题意:

输入n,l,r,表示从a1至an的值>=l同时<=r,要求i和ai的最大公约数不相同,如果可以构建数组

思路:

i的范围是1到n,那么最大公约数的范围也是1到n,那么我们就可以让gcd(i,ai)= i即可。

我们可以通过l对i的余数来快速查找大于等于l的i的倍数

代码:

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

int arr[100005];

int main(){
	int t;
	cin >> t;
	while(t--){
		int n, l, r;
		cin >> n >> l >> r;
		bool f = 0;
		for(int i = 1; i <= n; i++){
			int ans = l % i;
			if(ans == 0){
				arr[i] = l;
				continue;
			}
			if(l +  i - ans <= r){
				arr[i] = l + i - ans;
			}else{
				f = 1;
				break;
			}
		}
		if(f){
			cout << "NO" << endl;
		}else{
			cout << "YES" << endl;
			for(int i = 1; i <= n; i++){
				if(i != 1){
					cout << " ";
				}
				cout << arr[i];
			}
			cout << endl;
		}
	}
	return 0;
}

C. Doremy's IQ

题目链接:

Problem - C - Codeforces

题面:

?

题意:?

一个人的IQ为q,有n场比赛,第i天只能参加第i场比赛,如果比赛难度大于IQ,那么IQ就会下降,如果IQ为0就不能参加比赛了,问最多能参加多少场比赛?输入一个01串,0表示不参加,1表示参加

思路:

贪心的讲:如果最后一场比赛结束的时候IQ刚好为0,那么我们参加的比赛数是最多的。

所以我们可以倒着往前推来求解

若当前的q小于ai,那么我们就让当前的q++,那么这样子是我们后面的比赛都能参加的最优解

代码:

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

int arr[100005];
int vis[100005];
int main(){
	int t;
	cin >> t;
	while(t--){
		int n, q;
		cin >> n >> q;
		int ans = 0;
		map<int, map<int, int> > mp;
		for(int i = 0; i < n; i++){
			cin >> arr[i];
			vis[i] = 0;
		}
		int k = 0;
		for(int i = n - 1; i >= 0; i--){
			if(k >= arr[i]){
				vis[i] = 1;
			}else{
				if(k < q){
					vis[i] = 1;
					k++;
				}
			}
		}
		for(int i = 0; i < n; i++){
			cout << vis[i];
		}
		cout << endl;
	}
	return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-20 18:34:21  更:2022-07-20 18:36:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/14 0:48:52-

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