Codeforces Round 944 (Div. 4)

Codeforces Round 944 (Div. 4)

Codeforces Round 944 (Div. 4)
在这里插入图片描述

A. My First Sorting Problem

思路:久违的比大小

AC code:

void solve() {int x, y; cin>> x >> y;cout << min(x, y) << " " << max(x, y) << endl;
}

B. Different String

题意:给出一个字符串,是否能重排成新的字符串并输出新字符串;

思路:排序后比一遍,倒序后再比一遍;

AC code:

void solve() {string s; cin >> s;string t = s;sort(t.begin(), t.end());if (t != s) {cout << "YES" << endl;cout << t << endl;return;}reverse(t.begin(), t.end());if (t != s) {cout << "YES" << endl;cout << t << endl;return;}cout <<"NO" << endl;
}

C. Clock and Strings

题意:在圆形时钟上选择ab,cd四个点分别连线,看是否相交;

思路:看这四个点是不是交叉顺序排列的即可;

AC code:

bool check (int a, int b, int c, int d) {if (a > b) swap(a, b);if (c > d) swap(c, d);return (a < c && c < b && b < d) || (c < a && a < d && d < b);
}void solve() {int a, b, c, d;cin >> a >> b >> c >> d;if (check(a, b, c, d) || check(c, d, a, b)) {cout << "YES" << endl;} else {cout << "NO" << endl;}
}

D. Binary Cut

题意:将当前01字符串最少分割成多少个连续子串可以重新排列成字典序最小字符串;

思路:最多存在一个同时存在0和1的子串,可以将所有串分割成连续的0和1的子串,若存在至少一个01串,则答案-1即可;

AC code:

void solve() {string s; cin >> s;int ans = 0;int cnt = 0, pos = 0;for (int i = 1; i < s.size(); i ++) {if (s[i] != s[i - 1]) cnt ++;if (s[i] == '1' && s[i - 1] == '0') pos = 1;}ans = cnt;if (pos) ans --;cout << ans+1 << endl;
}

E. Find the Car

题意:

有0到n个站点,汽车从站点0开始行驶,已知汽车到达其中k个站点的时间,这k个站点之间的平均速度是相同的,即a1点到a2点为一个

平均速度,a2到a3点又是一个平均速度,不一定相同,不一定不同。

现在给出q个查询,每次查询0到n的其中一个点,询问到达该点的时间为多少。

思路:

二分查询时第一个大于当前查询点的l点,当前点的时间即为l-1点的时间 + l-1到l之间经过点的和;

注意,double会损失精度,在求单独一段时,用整型元素先乘后除才能减少精度损失,即:

所求距离 * l-1到l的总距离 / l-1到l的时间

AC code:

void solve() {int n, k, q; cin >> n >> k >> q;a[0] = 0, b[0] = 0;for (int i = 1; i <= k; i ++) cin >> a[i];for (int i = 1; i <= k; i ++) cin >> b[i];while (q --) {int d; cin >> d;int l = 1, r = k;while (l < r) {int mid = l + r >> 1;if (a[mid] > d) r = mid;else l = mid + 1;}if (n == d) {cout << b[k] << ' ';continue;}int ans = b[l - 1];ans += ((d - a[l - 1]) * (b[l] - b[l - 1]) / (a[l] - a[l - 1]));cout << ans << ' ';} cout << endl;
}

F. Circle Perimeter

题意:略,题面描述非常简洁;

思路:直接俩for暴力枚举r一定超时,所以我们先枚举x坐标,对于y坐标,我们只枚举大于r的最小y坐标到小于r+1的最大y坐标即可;

在坐标轴上的点贡献为2,其他的贡献为4;

AC code:

void solve() {int r; cin >> r;int cnt = 0;int r2 = r * r, rp = (r + 1) * (r + 1);for (int i = 0; i <= r + 1; i ++) {int x = i * i;int mn = (int)ceil(sqrt((double)max(0LL, r2 - x)));int mx = (int)floor(sqrt((double)(rp - 1 - x)));for (int y = mn; y <= mx; y ++) {if (x == 0 || y == 0) cnt += 2;else cnt += 4;}}cout << cnt << endl;
}

G. XOUR

题意:在n个非负整数的序列a中,可以任意交换两两异或值小于4的元素,求可能的最小字典序数组;

思路:可以发现,二进制下第一和第二位00,01,10,11的任何排列组合都是符合条件的,所以可以交换的元素除了首位和次位的二进制一定是相等的,我们存储这样相同的元素进行排列,按顺序输出即可;

这里很巧妙是可以用到map<int, priority_queue<int, vector, greater>> mp;来直接实现存储,排序,输出的目的;

存储过程中无需按位取,按x>>2进行存储即可;

AC code:

void solve() {int n; cin >> n;vector<int> a(n);map<int, priority_queue<int, vector<int>, greater<int>>> mp;for (int i = 0; i < n; i ++) {int x; cin >> x;a[i] = x;mp[a[i] >> 2].push(x);}for (int i = 0; i < n; i ++) {cout << mp[a[i] >> 2].top() << ' ';mp[a[i] >> 2].pop();} cout << endl;
}

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

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

相关文章

2024年最新趋势跨境电商平台开发需了解的新技术

随着数字化技术的不断演进和全球市场的日益融合&#xff0c;跨境电商平台开发将面临前所未有的挑战和机遇。为了更好地适应并引领这一发展&#xff0c;开发者需要密切关注2024年最新的技术趋势&#xff0c;以确保他们的平台能够在竞争激烈的市场中脱颖而出。本文将对跨境电商平…

【静态分析】软件分析课程实验A3-死代码检测

官网&#xff1a; 作业 3&#xff1a;死代码检测 | Tai-e 参考&#xff1a; https://www.cnblogs.com/gonghr/p/17981720 --------------------------------------------------------------------- 1 作业导览 为 Java 实现一个死代码&#xff08;dead code&#xff09;检…

Jenkins流水线部署Maven项目

使用Jenkins的流水线功能&#xff0c;构建部署Java Maven项目&#xff0c;步骤很简单但是不少细节需要注意。 一、安装 Jenkins的安装步骤和流程就不具体描述&#xff0c;这里主要介绍一下安装时要注意的几个问题。 1、Jenkins尽量安装最新的几个版本&#xff0c;否则安装完成…

6个超TM好用的神仙App推荐!

1. AI文本视频生成工具——Jurilu Jurilu 是一款功能强大的 AI 文本视频生成器&#xff0c;允许用户快速将文本内容转换成极具吸引力的视频。它的使用非常简单&#xff1a;只需要输入文字&#xff0c;选择想要的样式和模板&#xff0c;Jurilu 就会自动将文字转换成生动的视频。…

【C语言】/*操作符(下)*/

目录 一、操作符的分类 二、二进制和进制转换 2.1 进制 2.2 进制之间的转换 三、原码、反码、补码 四、单目操作符 五、逗号表达式 六、下标引用操作符[] 七、函数调用操作符() 八、结构体成员访问操作符 8.1 直接访问操作符(.) 8.2 间接访问操作符(->) 九、操作符…

干货教程【AI篇】| 目前全球最强AI换脸工具swapface详细图文教程及整合包下载

需要这个工具整合包的小伙伴可以关注一下文章底部公众号&#xff0c;回复关键词【swapface】即可获取。 从我们的链接下载&#xff0c;得到这个exe文件 双击运行即可进入安装界面 如下图所示已经在安装中啦 安装好之后我们根据上面的安装路径找到要执行的文件 双击红框中的…

Doris【部署 01】Linux部署MPP数据库Doris稳定版(下载+安装+连接+测试)

本次安装测试的为稳定版2.0.8官方文档 https://doris.apache.org/zh-CN/docs/2.0/get-starting/quick-start 这个简短的指南将告诉你如何下载 Doris 最新稳定版本&#xff0c;在单节点上安装并运行它&#xff0c;包括创建数据库、数据表、导入数据及查询等。 Linux部署稳定版Do…

Excel-VBA报错01-解决方法

【已删除的部件:部件/xl/vbaProject.bin。(Visual Basic for Applications(VBA))】 1.问题复现&#xff1a; Win10 &#xff1b;64位 &#xff1b;Office Excel 2016 打开带有宏的Excel文件&#xff0c;报错&#xff1a;【已删除的部件&#xff1a;部件/xl/vbaProject.bin。…

MFC DLL注入失败一些错误总结

使用cheat Engine为MFC窗口程序注入DLL时一定要注意&#xff0c;被注入的exe程序和注入的DLL 的绝对路径中一定不要带有中文字符&#xff0c;否则会遇到各种各样的奇怪错误&#xff0c;如下所示&#xff1a; 以下是dll绝对路径中均含有中文字符&#xff0c;会报错误&#xff…

一种简单的小报表本地缓存方案

适应如下场景&#xff1a;关联表多&#xff0c;接口响应慢&#xff0c;报表数据不多&#xff0c;可能就十多行。参数也固定&#xff0c;实时性要求不高&#xff0c;隔那么半小时刷新一次&#xff0c;查询性能要求高&#xff0c;给领导看的&#xff0c;要求很快。 使用示例&…

【桌面应用开发】Rust+Tauri框架项目打包操作

1.项目npm install下载项目依赖&#xff08;需要配置好node.js环境&#xff09; 可参考&#xff1a;https://blog.csdn.net/m0_64346565/article/details/138319651 2.自定义图标&#xff08;项目初始化开始第一次需要配置生成&#xff0c;后面可跳过这一步骤&#xff09; Ta…

ITIL4视角下的IT监控与故障管理:守护服务健康的双刃剑

引言&#xff1a;监控的曙光 在IT服务管理的浩瀚星图中&#xff0c;"监控"这一璀璨星辰终于得到了应有的重视与聚焦。ITIL4的出台&#xff0c;不仅明确将监控告警纳入事件管理的广阔宇宙&#xff0c;而且强调了其在预防故障、保障服务连续性中的核心地位。当组织拥抱…

k8s设置在任意node里执行kubectl 命令

一、问题 正常来讲kubectl 只能在master node 里运行 当我们尝试在某个 node 节点来执行时&#xff0c; 通常会遇到下面错误 执行错误&#xff1a;The connection to the server localhost:8080 was refused - did you specify the 原因&#xff1a;因为k8s的各个组建&#xf…

Oracle 多表查询

关联查询 一、sql:1992语法的连接笛卡尔积等值连接非等值连接自连接外连接 二、sql:1999语法的连接交叉连接自然连接USING创建连接ON创建连接左外连接右外连接FULL OUTER JOININNER JOIN 三、子查询子查询的种类单行子查询多行子查询 在From字句中使用子查询练习 四、行转列 一…

小兴教你做平衡小车-平衡车主板绘制(V4版本 b站课程所使用版本)

文章目录 1 原理图总览2 原理图各模块细致图2.1 2.54mm插针(stm32最小系统扩展接口)2.2 OLED显示2.3 MPU60502.4 TB6612驱动电路2.5 2.54mm排座(stm32最小系统连接接口)2.6 测距模块2.7 蓝牙模块2.8 蜂鸣器模块2.9 电池电压检测电路2.10 M3固定孔2.11 用户小灯模块2.12 电源接口…

在go-zero中使用jwt

gozero使用jwt 两个步骤 获取token验证token 前端获取token 先编写 jwt.api 文件&#xff0c;放在api目录下 syntax "v1"info (title: "type title here"desc: "type desc here"author: "type author here"email: &quo…

无限集中的最小数字

题目链接 无限集中的最小数字 题目描述 注意点 1 < num < 1000 解答思路 由题意得&#xff0c;可以理解为最初集合中有1~1000之间的所有数字&#xff0c;如果集合中存在数字&#xff0c;则添加时不会有任何操作&#xff1b;在移除集合中的元素时&#xff0c;会按顺序…

记录使用极空间NAS通过Docker部署小皮面板(PhpStydy)运行 八图片当面付支付宝接口 PHP项目的遭遇

事件的起因还得从我用八图片的图片加密支付跳转功能&#xff0c;实现打赏金额发案例源码下载链接挣个烟钱的事。八图片的支付接口是PHP web项目的。正好我有个极空间的NAS&#xff0c;搭建到NAS上省去了买主机的费用。 导读 八图片是什么&#xff1f;极空间NAS 部署 PHP网站安装…

Go实现树莓派读取at24c02 eeprom读写数据

步骤 启用i2c 参考 Go实现树莓派读取bh1750光照强度 代码 package mainimport ("fmt""periph.io/x/conn/v3/i2c" )type AT24C02Device struct {dev *i2c.Dev }func NewAT24C02Device(addr uint16, bus i2c.BusCloser) (*AT24C02Device, error) {var (d…

图像融合-下游任务(目标检测、实例分割、深度估计)

下游任务: 采用目标检测、实例分割和深度估计的下游任务来验证图像融合结果质量。 文章目录 下游任务:1.目标检测2.实例分割3.深度估计Update1.目标检测 YOLOv8:https://github.com/ultralytics/ultralytics 步骤内容第一步下载项目到本地第二步安装README中项目相关的环…