分糖果

题意

选择L~R中的某个数 , 使得x mod k的结果最大。

思路

分两种情况考虑:

若 L 和 R 对 K 取模后在同一区间,则必然在 x=R 位置取到最大值;

否则 L~R 必然跨越多个区间,则取模后的结果必然有 k-1。

而对于是否在同一区间,在除以 k 后,商是否一致判断即可。

参考代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main() {
ll n, l, r;
cin >> n >> l >> r;
if (l / n != r / n) cout << n - 1 << endl;
else cout << r % n << endl;
return 0;
}

插入排序

题意

给定长度为 n 的整数序列 ,有 Q 种操作:

1:x v 修改序列 a 中的第 x 个元素 a[x] 为 v ,该操作次数不超过5000次;

2:x 将数组进行稳定排序,求原先第 x 个元素排序后的位置。

思路

不如维护将原先所有的 a 排序后的升序数组。对于所有操作,我们需要维护原位置到有序数组中的映射。

对于 1 操作,找到 a[x] 对应位置,显然修改值将使其往前或往后。联系到题目中提示的插入排序,可以不断向前/向后比较。注意同时维护映射关系。

对于 2 操作,直接输出映射即可。

注:如果该题中的数组长度更长、操作次数更多,我们可使用平衡树来解决该题。

参考代码

#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> pii;
const int N = 8e3+5;
int a[N];
pii p[N]; int main() {
ios::sync_with_stdio(false);
int n, q; cin >> n >> q;
for (int i = 1; i <= n; i++) {
cin >> a[i];
p[i] = {a[i], i};
}
sort(p + 1, p + 1 + n);
for (int i = 1; i <= n; i++) a[p[i].second] = i;
for (int i = 0, op, x, v; i < q; i++) {
cin >> op;
// 5000 * 8000 = 4e7
if (op == 1) {
cin >> x >> v;
int pos = a[x];
p[pos].first = v;
while (pos > 1 && p[pos] < p[pos - 1]) {
swap(a[p[pos].second], a[p[pos - 1].second]);
swap(p[pos], p[pos - 1]);
pos--;
}
while (pos < n && p[pos] > p[pos + 1]) {
swap(a[p[pos].second], a[p[pos + 1].second]);
swap(p[pos], p[pos + 1]);
pos++;
}
} else {
cin >> x;
cout << a[x] << endl;
}
}
return 0;
}

网络连接

题意

解析带端口的IP地址串,按服务器和客户端角色判断连接情况。

思路

若将带端口的IP地址串记为 a.b.c.d:e,则需要检查的项目有:

  • 有三个点号和一个冒号分隔字符串,且冒号出现在最后;
  • a,b,c,d,e均不为空,且不含有前导零;

可将对字符串的解析抽象为函数,简化代码逻辑。

参考代码

#include<bits/stdc++.h>
using namespace std;
map<string, int> dict;
const int IP = 256;
const int PORT = 65536; bool check(string s, int limit) {
// ".0.0.1:80" -> ""
if (s.empty()) return false;
// "0127.0.0.1:80" -> "0127"
if (s[0] == '0' && s.size() > 1) return false;
int val = 0;
for (int i = 0; i < s.size(); i++) {
val = val * 10 + s[i] - '0';
if (val >= limit) return false;
}
return true;
} bool parse(string ip) {
string s = "";
int dot_cnt = 0, port_cnt = 0;
for (int i = 0; i < ip.size(); i++) {
if (ip[i] == '.') dot_cnt += 1;
if (ip[i] == ':') {
if (dot_cnt != 3) return false;
port_cnt += 1;
}
if (!isdigit(ip[i])) {
if (!check(s, IP)) return false;
s = "";
} else s += ip[i];
}
return check(s, PORT) && dot_cnt == 3 && port_cnt == 1;
} void process_server(string ip, int id) {
bool valid = parse(ip);
if (!valid) {cout << "ERR" << endl; return;}
if (dict.count(ip)) {cout << "FAIL" << endl; return;}
dict[ip] = id;
cout << "OK" << endl;
} void process_client(string ip) {
bool valid = parse(ip);
if (!valid) {cout << "ERR" << endl; return;}
if (!dict.count(ip)) {cout << "FAIL" << endl; return;}
cout << dict[ip] << endl;
} int main() {
ios::sync_with_stdio(false);
int n; cin >> n;
for (int i = 1; i <= n; i++) {
string name, ip;
cin >> name >> ip;
if (name[0] == 'S') process_server(ip, i);
else process_client(ip);
}
return 0;
}

小熊的果篮

题意

有两类共 n 个水果拍成一排,称连续的排在一起的同一种水果称为“块”。

每次将每一个“块”中最左边的水果同时挑出。重复该操作直至水果用完。

每次水果被挑出后“块”会发生动态变化。

思路

尝试建模每个块,使用块头来表示每个块的开始位置,即第一个元素或与上一个元素类型不同的位置。

每个元素之间使用双向链表相连接。

对于每次输出选出的元素,我们只需要依次输出块头元素,并从双向链表中删除该元素。

当块头元素输出后,需要更新块头列表。

考虑在原块头位置的下一个元素,只有当:

  • 该下一个元素与原块头位置的上一个元素类型不同;
  • 该下一个元素不是原块头。

则能够成为新的块头位置。

参考代码

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+5;
struct Node {
int pre, nxt, v;
}a[N];
vector<int> head, nxt_head; int main() {
ios::sync_with_stdio(false);
int n; cin >> n;
a[0].v = a[n + 1].v = -1;
a[0].nxt = 1;
a[n + 1].pre = n;
for (int i = 1; i <= n; i++) {
cin >> a[i].v;
a[i].pre = i - 1;
a[i].nxt = i + 1;
if (a[i].v != a[i - 1].v) head.push_back(i);
}
while(head.size()) {
nxt_head.clear();
for (int id : head) {
cout << id << " ";
Node& node = a[id];
a[node.pre].nxt = node.nxt;
a[node.nxt].pre = node.pre;
if (node.v == a[node.nxt].v && node.v != a[node.pre].v)
nxt_head.push_back(node.nxt);
}
cout << endl;
swap(head, nxt_head);
}
return 0;
}

CSP-J2021 题解的更多相关文章

  1. 上午小测3 T1 括号序列 && luogu P5658 [CSP/S 2019 D1T2] 括号树 题解

    前 言: 一直很想写这道括号树..毕竟是在去年折磨了我4个小时的题.... 上午小测3 T1 括号序列 前言: 原来这题是个dp啊...这几天出了好几道dp,我都没看出来,我竟然折磨菜. 考试的时候先 ...

  2. [CSP模拟测试43、44]题解

    状态极差的两场.感觉现在自己的思维方式很是有问题. (但愿今天考试开始的一刻我不会看到H I J) A 考场上打了最短路+贪心,水了60. 然而正解其实比那30分贪心好想多了. 进行n次乘法后的结果一 ...

  3. 题解 nflsoj489 【六校联合训练 CSP #15】小D与随机

    题目链接 考虑枚举好点的集合.此时要考虑的问题是如何填入\(1\sim n\)这些数使得恰好我们枚举到的这些点是好点,即:求出有多少种合法的填数方案. \(1\)号点一定是好点.那么除\(1\)号点外 ...

  4. CCF CSP 201703-3 Markdown

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-3 Markdown 问题描述 Markdown 是一种很流行的轻量级标记语言(l ...

  5. CCF计算机职业资格认证考试题解

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF计算机职业资格认证考试题解 CCF计算机软件能力认证(简称CCF CSP认证)是CCF计算机职业资格认证系 ...

  6. CCF CSP 201312-3 最大的矩形

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201312-3 最大的矩形 问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i( ...

  7. CCF CSP 201609-3 炉石传说

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201609-3 炉石传说 问题描述 <炉石传说:魔兽英雄传>(Hearthston ...

  8. CCF CSP 201403-3 命令行选项

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-3 命令行选项 问题描述 请你写一个命令行分析程序,用以分析给定的命令行里包含哪些 ...

  9. CCF CSP 201709-4 通信网络

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-4 通信网络 问题描述 某国的军队由N个部门组成,为了提高安全性,部门之间建立了M ...

  10. CCF CSP 201409-3 字符串匹配

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201409-3 字符串匹配 问题描述 给出一个字符串和多行文字,在这些文字中找到字符串出现的那 ...

随机推荐

  1. MySQL数据库和Oracle数据库的区别

    Mysql数据库 由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司.是一种中小型的关系型数据库. MySQL 数据库体积小.速度快.总体拥有成本低.开放源代码,其有着广泛的应用,一般中 ...

  2. TypeError: this.getOptions is not a function

    我在vue ui界面中安装版本依赖包后报这个错误 less-loader/sass-loader安装的版本过高 解决办法 删除原有的版本依赖包,安装更低版本的依赖包. 如 @6.0.1为选择安装的版本 ...

  3. 前端 关于请求地址时出现乱码, 出现%E2%80%8B的问题

    做项目时,添加了新的一个接口,习惯性地复制了接口下来.然后测试发现 请求时自动添加 了几个%E2%80%8B这种乱码. 问题原因: 我输出请求地址时也是正确的,是因为复制过来的接口地址会有零宽空格 解 ...

  4. 数字化转型之数字资产知识库(springboot+es+vue+neo4j)

    前言 在数字化高度普及的时代,企事业机关单位在日常工作中会产生大量的文档,例如医院制度汇编,企业知识共享库等.针对这些文档性的东西,手工纸质化去管理是非常消耗工作量的,并且纸质化查阅难,易损耗,所以电 ...

  5. 李呈祥:bilibili在湖仓一体查询加速上的实践与探索

    导读: 本文主要介绍哔哩哔哩在数据湖与数据仓库一体架构下,探索查询加速以及索引增强的一些实践.主要内容包括: 什么是湖仓一体架构 哔哩哔哩目前的湖仓一体架构 湖仓一体架构下,数据的排序组织优化 湖仓一 ...

  6. 【Redis】哨兵初始化和主观下线

    在的redis启动函数main(server.c文件)中,对哨兵模式进行了检查,如果是哨兵模式,将调用initSentinelConfig和initSentinel进行初始化,initServer函数 ...

  7. 8.shell编程之免交互

    shell编程之免交互 目录 shell编程之免交互 Here Document免交互 免交互定义 Here Document变量设定 多行的注释 expect expect 定义 expect基本命 ...

  8. 国内外组态软件对比分析(InTouch、WinCC、iFix、iNeuOS)

    在我国自动化控制领域应用较广泛的工业自动化组态软件有Wonderware公司InTouch.西门子公司Wincc.GE公司iFix.国内也有一些传统组态软件厂商,使用的功能和形式基本上十分类似,受当时 ...

  9. 基于web3D展示技术的煤矿巷道3D可视化系统

    地下开采离不开巷道工程.煤矿的生产.运输.排水.通风等各个环节都少不了巷道的支持.在煤矿智能化建设被提上日程的今天,巷道工程的智能化.可视化建设也成了行业趋势.尤其是复杂的井下作业环境,人员信息安全问 ...

  10. 论文解读(SR-GNN)《Shift-Robust GNNs: Overcoming the Limitations of Localized Graph Training Data》

    论文信息 论文标题:Shift-Robust GNNs: Overcoming the Limitations of Localized Graph Training Data论文作者:Qi Zhu, ...