Codeforces Round 942 (Div. 2) A-D1

news2024/12/24 4:05:06

题目: Codeforces Round 942 (Div. 2)

D2有缘再补吧…


A. Contest Proposal

题意

两个升序(不降)的序列a和b,可以在a的任意位置插入任意数(要保持升序),使对任意i,有a[i] <= b[i],问最少插入几次

思路

对于某个位置i插入什么数不用考虑,总有保持升序又满足a[i] <= b[i]的办法的,插入这个操作就相当于把a数组在i之后的部分后移一格
可以从前往后依次插入,这样前边的序列都是满足条件的不用管,后边依次判断要不要插入(如果a[i] > b[i]就要插入)

代码

i是遍历a数组看要不要插入,j是a[i]对应的b数组下标
总之把后移操作换成了移下标,i没动j后移说明a[i]对应的数还在后面,需要后移,答案加一
(我在说什么

#include <iostream>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <cstring>
#include <algorithm>
using namespace std;

typedef long long ll;
const int N = 105;

int a[N], b[N]; 

int main()
{
	int T, n;
	cin >> T;
	while (T--)
	{
		cin >> n;
		for (int i = 0; i < n; i++)
			cin >> a[i];
		for (int i = 0; i < n; i++)
			cin >> b[i];
		int ans = 0;
		int i = 0, j = 0;
		while (i < n)
		{
			while (j < n && a[i] > b[j])
			{
				j++;
				ans++;
			}
			i++, j++;
		}
		cout << ans << endl;
	}
	return 0;
}

B. Coin Games

题意

n个硬币,每个硬币有U或者D两个状态(朝上朝下),操作:选一个硬币取走,并把周围两个硬币翻面,玩家A和B依次操作,无法操作判输

思路

列了一些必赢必输的情况,然后发现这不U单数就必赢吗
在这里插入图片描述

代码

#include <iostream>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <cstring>
#include <algorithm>
using namespace std;

typedef long long ll;
const int N = 105;

int a[N], b[N]; 

int main()
{
	int T, n;
	cin >> T;
	while (T--)
	{
		cin >> n;
		string str;
		cin >> str;
		int cnt = 0;
		for (int i = 0; i < str.size(); i++)
		{
			if (str[i] == 'U') cnt++;
		}
		if (cnt & 1) cout << "yes\n";
		else cout <<"no\n";
	}
	return 0;
}

C. Permutation Counting

题意

对i(1…n),你手头有a[i]张写着i的卡,你可以再任意买k张卡(1…n),问最终你手头的卡最多能凑出多少1-n的排列

思路

贪心,首先尽凑出尽可能多套[1-n]
也就是k要先补给数量少的卡 -> 排序,补前边的
枚举要凑出的[1-n]数,判断是否可行 -> 二分答案

假设最多能凑出x个[1-n],先把他们按同样的顺序(这个顺序好像有讲究但是反正不用输出)依次摆开,这样就有x * n - n + 1个排列了
有多的卡(指最后数量>= x + 1)摆在两边,每个数只能摆一次,每摆一个答案加一(总有一个排列顺序↑满足这点),所以答案要加上本来数量就>= x+1的卡 + k补完x个[1-n]后还剩的部分
(剩下的k肯定拿去买数量不够x+1的了,这样答案最大化,而且够不到的卡数一定大于剩下的k,因为小于等于的话都可以再凑一波[1-n]了)

代码

答应我技艺不精就全用long long好吗,在这de半天(给自己一拳
二分,lower_bound,upper_bound我一生之敌

#include <iostream>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;

typedef long long ll;
const int N = 2e5 + 5;

ll a[N], sum[N];
int n;
ll k;

ll cal(ll x)//如果要凑出x个[1-n],需要补多少卡
{
	int p = lower_bound(a + 1, a + n + 1, x) - a - 1;
	return x * p - sum[p];
}

int main()
{
	int T;
	cin >> T;
	while (T--)
	{
		cin >> n >> k;
		for (int i = 1; i <= n; i++)
			cin >> a[i];
		sort(a + 1, a + n + 1);//排序!
		sum[0] = 0;
		for (int i = 1; i <= n; i++)
			sum[i] = sum[i - 1] + a[i];//前缀和!好算!
		
		ll l = a[1], r = a[1] + k;
		while (l < r)
		{
			ll mid = l + r + 1 >> 1;
			if (cal(mid) <= k) l = mid;
			else r = mid - 1;
		}
		//printf("l %lld\n", l);
		
		k = k - cal(l);
		int p = upper_bound(a + 1, a + n + 1, l) - a - 1;//这里要求第一个本来数量就>= x+1的卡的下标(实际上是p + 1),所以要用upper_bound
		ll res = l * n - n + 1 + k + n - p; //l个[1-n]的 + 剩下的k + 本来就>= x+1的卡数
		cout << res << endl;
	}
	return 0;
}

D1. Reverse Card (Easy Version)

思路

d = gcd(a, b)a = ka * d, b = kb * d

b * d | a + b
b | ka + kb
kb * d | ka + kb
kb | ka

故有gcd(a, b) = b,设a = k * b

b * b | k * b + b
b | k + 1

k + 1 = k' * b,则a = (k' * b - 1) * b = k' * b * b - b
对于每个b,有(n + b) / b * b个k’满足a在n范围内
枚举b,算a的个数
(好绕啊…写个博客重推一遍还是没懂思路

代码

#include <iostream>
#include <cstdio>
#include <vector>
#include <cmath>
#include <queue>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;

typedef long long ll;
const int N = 2e6 + 5;

int main()
{
	ll T, n, m;
	cin >> T;
	while (T--)
	{
		cin >> n >> m;
		ll ans = n;
		for (ll i = 2; i <= m; i++)
		{
			ll t = i * i;
			ans += (n + i) / t;
			//if (n/t) cout << i << ' ' << n / t << endl;
		}
		cout << ans << endl;
	}
	return 0;
}

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

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

相关文章

ENVI下实现遥感矿物蚀变信息提取

蚀变岩石是在热液作用影响下&#xff0c;使矿物成分、化学成分、结构、构造等发生变化的岩石。由于它们经常见于热液矿床的周围&#xff0c;因此被称为蚀变围岩&#xff0c;蚀变围岩是一种重要的找矿标志。利用围岩蚀变现象作为找矿标志已有数百年历史&#xff0c;发现的大型金…

ldap对接jenkins

ldap结构 配置 - jenkins进入到 系统管理–>全局安全配置 - 安全域 选择ldap - 配置ldap服务器地址&#xff0c;和配置ldap顶层唯一标识名 配置用户搜索路径 - 配置管理员DN和密码 测试认证是否OK

Java | Leetcode Java题解之58题最后一个单词的长度

题目&#xff1a; 题解&#xff1a; class Solution {public int lengthOfLastWord(String s) {int index s.length() - 1;while (s.charAt(index) ) {index--;}int wordLength 0;while (index > 0 && s.charAt(index) ! ) {wordLength;index--;}return wordL…

《设计一款蓝牙热敏打印机》

主控芯片用易兆威蓝牙ic&#xff0c;通讯接口&#xff1a;蓝牙、串口、usb 安卓apk用java kotlin编写、上位机用Qt编写。

基于51单片机的自动售货机系统

一、项目概述 本文设计了一款以AT89C51单片机为核心的自动售货机系统&#xff0c;并且着重详细地介绍了自动售货机的整体系统设计方案、硬件选择基础、软件使用方法及技巧。 以AT89C51作为CPU处理单元连接各个功能模块&#xff1b;以44矩阵键盘作为输入控制模块对货物进行种类…

一文了解栈

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、栈是什么&#xff1f;二、栈的实现思路1.顺序表实现2.单链表实现3.双向链表实现 三、接口函数的实现1.栈的定义2.栈的初始化3.栈的销毁4.入栈5.出栈6.返回栈…

爆赞好文之java反序列化之CB超详细易懂分析

java反序列化之CB超详细易懂分析 CB1环境搭建前言分析PropertyUtilsBeanComparatorPriorityQueue CB2环境搭建前言exp CB1 环境搭建 pom.xml <dependencies><dependency><groupId>commons-beanutils</groupId><artifactId>commons-beanutils&l…

回归预测 | Matlab实现基于CNN-SE-Attention-ITCN多特征输入回归组合预测算法

回归预测 | Matlab实现基于CNN-SE-Attention-ITCN多特征输入回归组合预测算法 目录 回归预测 | Matlab实现基于CNN-SE-Attention-ITCN多特征输入回归组合预测算法预测效果基本介绍程序设计参考资料 预测效果 基本介绍 【模型简介】CNN-SE_Attention结合了卷积神经网络&#xff…

12V系统车灯电源口浪涌过压防护方案及保护器件选型推荐

12V系统车灯驱动电源口浪涌过压防护方案图 12V系统车灯驱动电源口浪涌过压防护方案详解 从图中可知&#xff0c;方案针对车灯驱动电路电源输入口的浪涌过压保护。在车载12V系统中&#xff0c;电源线上面的瞬态浪涌主要来源于抛负载。在12V系统车灯驱动电源输入端&#xff0c;东…

Scroll生态项目Penpad,再获Presto Labs的投资

Penpad是Scroll生态的LaunchPad平台&#xff0c;其整计划像收益聚合器以及RWA等功能于一体的综合性Web3平台拓展&#xff0c;该平台在近期频获资本市场关注&#xff0c;并获得了多个知名投资者/投资机构的支持。 截止到本文发布前&#xff0c;Penpad已经获得了包括Scroll联合创…

6.移除元素

文章目录 题目简介题目解答解法一&#xff1a;双指针代码&#xff1a;复杂度分析&#xff1a; 解法二&#xff1a;双指针优化代码&#xff1a;复杂度分析&#xff1a; 题目链接 大家好&#xff0c;我是晓星航。今天为大家带来的是 相关的讲解&#xff01;&#x1f600; 题目简…

【计组OS】访存过程以及存储层次化结构

苏泽 本专栏纯个人笔记作用 用于记录408 学习的笔记记录&#xff08;敲了两年码实在不习惯手写笔记了&#xff09; 如果能帮助到大家当然最好 但由于是工作后退下来备考 很多说法和想法都会结合实际开发的思想 可能不是那么的纯粹应试哈 希望大家挑选自己喜欢的口味食用…

语音识别--光谱门控降噪

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计7267字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

QT程序简单国际化实验

文章目录 第一步&#xff1a;新建一个QT工程第二步&#xff1a;添加控件第三步&#xff1a;在pro文件中添加内容第四步&#xff1a;更新文件第五步&#xff1a;打开QT的Linguist第六步&#xff1a;添加翻译内容第七步&#xff1a;回到QT Creator中添加文件第八步&#xff1a;给…

Linux 进程间通信之共享内存

&#x1f493;博主CSDN主页:麻辣韭菜&#x1f493;   ⏩专栏分类&#xff1a;Linux知识分享⏪   &#x1f69a;代码仓库:Linux代码练习&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习更多Linux知识   &#x1f51d; ​ 目录 ​编辑​ 前言 共享内存直接原理…

标准IO学习

思维导图&#xff1a; 有如下结构体 struct Student{ char name[16]; int age; double math_score; double chinese_score; double english_score; double physics_score; double chemistry_score; double bio_score; }; 申请该结构体数组&#xff0c;容量为5&#xff0c;初始…

dstat 与系统 I/O

知道系统运行了哪些服务也许并不能告诉你是谁拖慢了系统。 top 命令可以报告CPU占用情况以及I/O等待时间&#xff0c;但这可能也不足以找出导致系统过载的任务。 跟踪I/O以及上下文切换有助于揪出问题的源头。 dstat 实用工具可以为你指出系统潜在的瓶颈。 …

【Qt 学习笔记】Qt常用控件 | 输入类控件 | Date/Time Edit的使用及说明

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt常用控件 | 输入类控件 | Spin Box的使用及说明 文章编号&#xff1…

1-2 ARM单片机GPIO

def&#xff1a;通用输入输出口 GPIO输出模式原理讲解 1&#xff1a;推挽输出 2&#xff1a;复用推挽输出 电流最大是20mA&#xff0c;对于单片机来说总体的输出是由范围的 开漏/复用开漏输出 外部接上拉电阻的开漏输出 线与的概念 注&#xff1a; 与的概念&#xff1a;全1为1&…

Django调用MTP服务器给指定邮箱发送邮件

Django调用MTP服务器发送邮箱 邮箱的激活链接含有用户数据不能直接发送需要对其进行加密 发送邮箱是借助SMTP服务器进行中转 一. 配置SMTP服务中的邮箱信息以及激活链接 1. 配置邮箱权限 打开网易邮箱设置点击POP3 开启选项 注 : 在打开的过程中会弹出授权密码一点要保存 …