Codeforces Round 900 (Div. 3)

Dashboard - Codeforces Round 900 (Div. 3) - Codeforces

C. Vasilije in Cacak

用等差数列求出能够构造出的最小值与最大值,判断x是否在这个范围内,如果在则能被构造出,此为结论,能被构造出的数为最小值与最大值之间的每一个数(如果有数小就往后移1)

一段数的和:(首项 + 末项) * 项数 / 2

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int solve()
{
	ll n, k, x, minn, maxx;
	cin >> n >> k >> x;
	minn = (1 + k) * k / 2;
	maxx = (n - k + 1 + n) * k / 2;
	if(x >= minn && x <= maxx)cout << "YES" << '\n';
	else cout << "NO" << '\n';
}
int main()
{
	int t;
	cin >> t;
	while(t --)
	{
		solve();	
	} 
	return 0;
}

D. Reverse Madness

将x看作一点,ri + li - x看作另一点,由于要翻转多次,可以每翻转一下记录一次,如果翻转了偶数次相当于没有翻转,不然就相当于翻转一次

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
void solve()
{
	int n, k, q, x;
	string s;
	cin >> n >> k;
	cin >> s;
	vector<int> l(k + 10, 0) , r(k + 10, 0), cnt (n + 1);
	for(int i = 1; i <= k; i ++)
	{
		cin >> l[i];
		l[i] --;
	}
	for(int i = 1; i <= k; i ++)
	{
		cin >> r[i];
		r[i] --;
	}
	cin >> q;
	while(q --)
	{
		cin >> x;
		cnt[x - 1] ++;
	}
	for(int i = 1; i <= k; i ++)
	{
		int ll = l[i];
		int rr = r[i];
		int sum = 0;
		for(int j = ll; j <= (ll + rr) / 2; j ++)
		{
			sum += cnt[j] + cnt[rr + ll - j];
			if(sum & 1)swap(s[j], s[rr + ll -j]);
		}
	}
	cout << s << '\n';
}
int main()
{
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	int t;
	cin >> t;
	while(t --)
	{
		solve();
	}
	return 0;
}
相关推荐
Lee_yayayayaya3 分钟前
本原多项式产生m序列的原理
算法
许长安21 分钟前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
Murphy_lx40 分钟前
C++ thread类
开发语言·c++
月夜的风吹雨41 分钟前
【C++ STL 深度剖析】:vector 底层模拟实现与核心陷阱解析
c++·vector·类和对象·visual studio
彩妙不是菜喵1 小时前
C++ 中 nullptr 的使用与实践:从陷阱到最佳实践
开发语言·jvm·c++
蒙奇D索大1 小时前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
逐步前行1 小时前
C数据结构--排序算法
c语言·数据结构·排序算法
王哈哈^_^1 小时前
【数据集+完整源码】水稻病害数据集,yolov8水稻病害检测数据集 6715 张,目标检测水稻识别算法实战训推教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
light_in_hand1 小时前
内存区域划分——垃圾回收
java·jvm·算法
小安同学iter2 小时前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50