题解 - Japanese Student Championship 2021
前言:这场的题解由于蓝桥杯比赛拖延几天才发
关于本篇题解,目前还是有部分题没有解答出来正在加油补题ing
补题链接:Here
A - Competition
题意:给定 \(X,Y,Z\) 代表的意义为,超市一以 Y 元卖 X 克食料包
现在超市二的一包食料包重 \(Z\) 克,请问超市二的售价为多少才能比超市一便宜
思路:
理解一下题意就容易发现:\(\lfloor\frac{YZ - 1}{X}\rfloor\)
B - Xor of Sequences
给定两个严格上升的整数序列 A,B,现求仅出现在A和B的数字,最后结果升序打印
思路:
由于两个序列数据范围不大,直接暴力循环即可
然后赛后看了一下高rank的代码发现了一个函数:set_symmetric_difference
**set_symmetric_difference **可构造区间S1,S2的对称差集(出现于S1但不出现于S2的元素以及出现于S2但不出现于S1的元素);返回值为指向输出区间的尾端。
void solve() {
int n, m;
cin >> n >> m;
vector<int> A(n), B(m);
for (int &x : A) cin >> x;
for (int &x : B) cin >> x;
vector<int> C;
set_symmetric_difference(A.begin(), A.end(), B.begin(), B.end(), back_inserter(C));
for (int x : C) cout << x << " ";
}
C - Max GCD 2
题意:给定一个区间,问 \(A \le x < y \le B\) 求问最大的 \(gcd(x,y)\)
说实话,比赛的时候还真没想到这个方法。
思路:
由于数对 \((x,y)\) 的个数最多 \(2\times 10^{10}\) ,所以我们不可能计算每一对 \((x,y)\) ,相反的、并考虑是非问题“是否存在一对 \((x,y)\) 使得 \(gcd (x,y) = c\)?”
因为 \(c\) 是最大公约数,所以 \(x,y\) 都应该是 \(c\) 的倍数,相反如果在 \([A,B]\) 区间中 \(c\) 的倍数多于两个值,则可以选择 \(x,y\) 使得 \(gcd(x,y) = c\) 成立
由于 \(B \le 2\times10^5\) 所以运行速度会足够快
把上面的话转化为数学表达式:A ~ B 之间 C 的倍数 = (C 的倍数在 \(1\) ~ \(B\) 之间) - (C 的倍数在 \(1\) ~ \(A\) 之间)= \(\lfloor\frac{B}{c}\rfloor - \lfloor\frac{A - 1}{c}\rfloor\)
再转化一下就是检查 \(\lfloor\frac{A}{c}\rfloor < \lfloor\frac{B}{c}\rfloor\)
Show Code
void solve() {
int A, B;
cin >> A >> B;
for (int c = B;; c--)
if ((A + c - 1) / c < B / c) {
cout << c << endl;
return;
}
}
D - Nowhere P
给定质数 \(P\) ,求有多少序列 \((A_1,A_2,\dots,A_N)\) 满足:
\]
显然,当 \(n = 1\) 时答案为 \(P - 1\) ,对应合法序列为 \((1),(2),\dots,(p - 1)\)
之后在这些合法序列后插入新数时,每个序列都有且仅有一个数使得这个数插入后该序列非法(该数即为 \((-\sum_ia_i)\ mod\ p\)
故答案为:\((p -1)(p-2)^{N-1}\)
跑 qpow 的时候记得取模
Show Code
const int mod = 1e9 + 7;
ll qpow(ll a, ll b) {
ll ans = 1;
a %= mod;
for (; b; b >>= 1, a = a * a % mod)
if (b & 1) ans = ans * a % mod;
return ans;
}
void solve() {
ll N, P;
cin >> N >> P;
cout << (P - 1) * qpow(P - 2, N - 1) % mod;
}
E - Level K Palindrome
本题所有的字符串均指只由小写英文字母构成的字符串
对字符串 \(s\),
- 定义其反转为: \(\operatorname{rev}(s)\), 则 \(s\) 是回文串 \(\Longleftrightarrow\) \(s = rev(s)\)
- \(+\) 运算定义为字符串的拼接
- 定义字符串上的变换为:将其中某一字符替换为一小写英文字母
定义 \(k\) 阶回文串如下:
- 空串,非回文串为 \(0\) 阶回文串
- 对 \(i\) 阶非空回文串 \(s\) 定义 \(s + rev(s)\) 为 \(i + 1\) 阶回文串
- 对 \(i\) 阶非空回文串 \(s\) 和单个字符 \(c_i\) \(s + c + rev(s)\) 为 \(i + 1\) 阶回文串
给一字符串 \(s\) 问至少经几次变换可使其恰好为 \(k\) 阶回文串
解题思路
显然,若有解则 \(k\) 不可能过大
待补
F - Max Matrix
有一个长为 \(n\) 的全零序列 \(a\) 和长为 \(m\) 的全零序列 \(b\) ,对其做如下操作
- 将 \(a\) 中的某个数赋一个值
- 将 \(b\) 中的某个数赋一个值
这两种操作一共进行 \(Q\)次,要求每次操作后都要输出
\]
待补
G - Spanning Tree
有n个点,考虑以这n个点为顶点,满足如下条件的所有图:
- 无向图
- 给出一个矩阵 \(A\)
- 若 \(A_{i,j}=0\),则点 \(i\) 和点 \(j\) 间没有边
- 若 \(A_{i,j}=0\),则点 \(i\) 和点 \(j\) 间没有边
- 若 \(A_{i,j}=-1\),则为上述两种情况的任-种
求这些图中树的个数
思路
首先,考虑所以已经存在的边构成的图,如果有环了,则答案一定为0,否则森林中的每个树都可缩成一个点,之后用矩阵树定理即可
H - Shipping
给一个带权无向图,求满足如下条件的子图的最小边权和
\]
题解 - Japanese Student Championship 2021的更多相关文章
- @atcoder - Japanese Student Championship 2019 Qualification - F@ Candy Retribution
目录 @description@ @solution@ @accepted code@ @details@ @description@ 请找到满足以下条件的长度为 N 的非负整数序列 A1, A2, ...
- @atcoder - Japanese Student Championship 2019 Qualification - E@ Card Collector
目录 @description@ @solution@ @accepted code@ @details@ @description@ N 个卡片放在 H*W 的方格图上,第 i 张卡片的权值为 Ai ...
- PAT甲级题解-1047. Student List for Course (25)-排序
一开始是建立了course[2501][40001]数组,存储每节课的学生编号然后for循环两层输出,但这样复杂度为O(2500*40000),也很明显导致最后时间超时后来发现最多40000学生,每个 ...
- yhm的丘赛题解(其中的一些简单题)
有选择地做了丘赛里的一些简单题,不定期更新 目录 [简单组合数学]2011丘赛个人[应数计算数学概统]第3题题解 [拉格朗日多项式插值]2011丘赛个人[应数计算数学概统]第2题题解 [概率] ...
- MySql基本查询、连接查询、子查询、正则表达查询解说
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 查询数据指从数据库中获取所须要的数据.查询数据是数据库操作中最经常使用,也是最重要的操作.用户 ...
- 35. Romantic Love and Ideal Romantic Relationship 爱情及理想爱情关系
35. Romantic Love and Ideal Romantic Relationship 爱情及理想爱情关系 ① Romantic love has clear evolutionary r ...
- mysql数据库查询
查询数据指从数据库中获取所需要的数据.查询数据是数据库操作中最常用,也是最重要的操作.用户可以根据自己对数据的需求,使用不同的查询方式.通过不同的查询方式,可以获得不同的数据.MySQL中是使用SEL ...
- Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查询数据指从数据库中获取所需要的数据.查询数据是数据库操作中最常用,也是最重要的操作.用户可以根据自己对数据的需求,使用不同的查询方式.通过不同的查询方式,可以获得不同的数据.MySQL中是使用SEL ...
- OI卷题记录
2021.8.2 LG3386 匈牙利算法 二分图 LG1377 笛卡尔树 题解 2021.8.3 LG2962 \(\text{Meet in middle}\) LG3389 高斯消元 高斯-约旦 ...
- Solution Set - 神奇 NOIP 模拟赛
\[\mathfrak{\text{Defining }\LaTeX\text{ macros...}}\newcommand{\vct}[1]{\boldsymbol{#1}}\newcommand ...
随机推荐
- 使用funcgraph-retval和bpftrace/kprobe快速定位并解决cpu控制器无法使能的问题
版本 Linux 6.5 背景 在学习cgroupv2的时候,想给子cgroup开启cpu控制器结果失败了: # 查看可以开启哪些控制器 root@ubuntu-vm:/sys/fs/cgroup# ...
- 快速认识什么是:Docker
Docker,一种可以将软件打包到容器中并在任何环境中可靠运行的工具.但什么是容器以及为什么需要容器呢?今天就来一起学快速入门一下Docker吧!希望本文对您有所帮助. 假设您使用 Cobol 构建了 ...
- 最好用的AI换脸软件,rope下载介绍
随着AI技术的广泛运用,市面上的换脸软件也多了起来,今天给各位介绍其中的王者Rope! 先上两个动图,给大伙看看效果 rope是如何实现这种自然的效果呢?这得益于机器学习技术的不断发展,rope经过深 ...
- 2023年度低代码平台企业TOP50榜单公布—以开源起家的JeecgBoot格外亮眼
近日,中国科学院主管.科学出版社主办的国家级核心期刊<互联网周刊>联合eNet研究院.德本咨询评选的<2023低代码企业50强>榜单正式公布.这一榜单的公布引起了业内外的广泛关 ...
- redis + AOP + 自定义注解实现接口限流
限流介绍 限流(rate limiting) 是指在一定时间内,对某些资源的访问次数进行限制,以避免资源被滥用或过度消耗.限流可以防止服务器崩溃.保证用户体验.提高系统可用性. 限流的方法有很多种 ...
- Pikachu漏洞靶场 ../../(目录遍历)
目录遍历 概述 在web功能设计中,很多时候我们会要将需要访问的文件定义成变量,从而让前端的功能便的更加灵活.当用户发起一个前端的请求时,便会将请求的这个文件的值(比如文件名称)传递到后台,后台再执行 ...
- C++ 学习宝藏网站分享
C++ 学习宝藏网站分享 1. C++ 在线参考手册 Cppreference https://zh.cppreference.com C++ 开发者必备的在线参考手册,是我最常访问的 C++ 网站之 ...
- 【manim动画教程】--目录(完结)
manim是一个生成数学教学视频的动画引擎. 它用编程的方式创建精美的数学动画,让数学更加易懂. 本教程简单介绍了 manim 的基本使用方式,基于 v0.17.2 版本 manim 安装 manim ...
- 如何快速部署本地训练的 Bert-VITS2 语音模型到 Hugging Face
Hugging Face是一个机器学习(ML)和数据科学平台和社区,帮助用户构建.部署和训练机器学习模型.它提供基础设施,用于在实时应用中演示.运行和部署人工智能(AI).用户还可以浏览其他用户上传的 ...
- Java 将Excel工作簿按工作表拆分为多个文档
本文介绍在Java代码环境中如何将Excel工作簿按工作表拆分为多个Excel文档,即:把Excel工作簿中的每一个工作表单独保存为一个Excel工作簿文件. 思路及方法:通过将源文档中的每个工作表通 ...