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;
}
相关推荐
CoovallyAIHub2 小时前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
NineData3 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
木心月转码ing4 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
会员源码网7 小时前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱8 小时前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱9 小时前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法
CoovallyAIHub1 天前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github