暑假集训CSP提高模拟8
一看见题目列表就吓晕了,还好我是体育生,后面忘了
唉这场比赛没啥好写的,要不就是太难要不就是太简单要不就是拉出去写在专题里了
A. 基础的生成函数练习题
考虑到只有奇偶性相同才能尝试加二,因此先用加一调平奇偶性,再直接加而就行了.
#include<bits/stdc++.h>
using namespace std;
int main(){
long long a,b,c;long long ans=0;
cin>>a>>b>>c;
int a2=a&1,b2=b&1,c2=c&1;
if(a2==c2 and a2==b2);
else if(a2==c2 and a2!=b2){
ans++;a++,c++;
}
else if(a2==b2 and a2!=c2){
ans++;a++,b++;
}
else if(b2==c2 and a2!=b2){
ans++;b++,c++;
}
ans+=(3ll*max({a,b,c})-a-b-c)/2;
cout<<ans<<endl;
}
B.简单的拉格朗日反演练习题
我:学长你卡线段树有什么深意吗
学长:没卡线段树,那是你常数写大了
但是线段树把原题过了,详见 这个专题
C.容易的多元拉格朗日反演练习题
记 \(S = \sum_{1\le i\le n} a_i\),\(S_A\) 为 Alice 擦掉的数之和,\(S_B\) 为 Bob 擦掉的数之和。
记一个长为 \(m\) 序列 \(b_i\) 的邻项差分 \(\text{diff }b = (b_2 - b_1) + (b_4 - b_3) + \cdots + (b_m - b_{m-1})\)。
首先转化题意。条件 \(l \le S_A \le r\) 可以通过整体乘 \(2\) 减 \(S\) 转化为 \(2L - S \le S_A - S_B \le 2R - S\)。随后设 \(x = S - (l + r)\),整体加 \(x\) 后变为 \(l - r \le x + S_A - S_B \le r - l\),即 \(|x + S_A - S_B| \le r - l\)。
因此有转化后的问题:
给定整数 \(x\)。两人轮流操作,每次选择一个没有选过的数字 \(a_i\)。在 Alice 的回合,置 \(x=x + a_i\),而在 Bob 的回合置 \(x=x - a_i\)。最终的分数即为 \(x\) 的绝对值。Alice 的目标是最小化这个值,而 Bob 的目标是最大化它。求当两方都采取最优策略情况下的赢家。
不妨假设 \(a_i\) 升序排列。我们断言,最终的分数可以通过如下方式求得:
- 选择整数 \(p\),将 \(p, p + x, a_1, a_2,\cdots, a_n\) 升序排列得到 \(A_i\)。令 \(p\) 的答案为 \(\text{diff }A\) 的值。
- 最终的分数即为所有可能的 \(p\) 的答案中的最小值。
容易发现 \(p\) 所有对答案有贡献的取值为 \(p = a_i\)。对于 \(p\) 的某一确定取值可以在 \(O(n)\) 的时间复杂度内计算答案,取其中最小值作为最终分数即可
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,a[5001];
vector<int>ans;
signed main(){
int cases;cin>>cases;while(cases--){
int l,r;
cin>>n>>l>>r;
int sum=0;
for(int i=1;i<=n;++i){
cin>>a[i];
sum+=a[i];
}
sum-=l+r;
sort(a+1,a+n+1);
int ret=LLONG_MAX,now;
for(int i=1;i<=n;++i){
ans.clear();
now=0;
for(int j=1;j<=n;++j){
if(i!=j){
ans.push_back(a[j]);
}
}
ans.insert(lower_bound(ans.begin(),ans.end(),a[i]+sum),a[i]+sum);
for(int j=0;j<=(int)ans.size()-1;j+=2){
now+=ans[j+1]-ans[j];
}
ret=min(ret,now);
}
cout<<(abs(ret)<=r-l?"Alice":"Bob")<<endl;
}
}
D. 朴素的抽象代数题
不是,你们怎么都不打暴力的啊
放一个暴力辅助理解题面吧
#include<bits/stdc++.h>
using namespace std;
unsigned long long l;
class _function{
private:
int a[26];
public:
int&operator[](int id){
return a[id];
}
inline void equal_func(){
for(int i=0;i<(int)l;++i){
a[i]=i;
}
}
_function operator+(_function A){
_function ans;
for(int i=0;i<(int)l;++i){
ans[i]=A[this->operator[](i)];
}
return ans;
}
void operator+=(_function A){
*this=*this+A;
}
void print(){
for(int i=0;i<(int)l;++i){
cout<<a[i]<<" ";
}
cout<<endl;
}
string func(string x){
string ans;
for(char i:x){
ans.push_back(this->a[i-'a']+'a');
}
return ans;
}
void operator =(std::vector<int>x){
for(int i=0;i<=(int)x.size()-1;++i){
a[i]=x[i];
}
}
}fu[3001];
typedef unsigned long long ull;
ull n,m,q,STR_LEN,seed1,seed2,FREQ,MAX_X;
int f[26],LEN;
ull xorShift128Plus(){
ull k3=seed1,k4=seed2;
seed1=k4;
k3^=(k3<<23);
seed2=k3^k4^(k3>>17)^(k4>>26);
return seed2+k4;
}
template<typename T>
void my_shuffle(T __first,T __last){
if(__first==__last) return;
for(T __i=__first+1;__i!=__last;++__i)
std::iter_swap(__i,__first+xorShift128Plus()%(int(__i-__first)+1));
}
vector<int>fun;
struct act{
bool type;
int a;
string b;
}ac[3001];
string ans[100001];
ull getHash(string ch){
ull hsh=0;
for (int i=0;i<=(int)ch.length()-1;i++){
hsh=hsh*131+ch[i];
}
return hsh;
}
signed main(){
scanf("%llu %llu %llu %llu %llu %llu %llu %llu %llu",
&n,&m,&q,&l,&seed1,&seed2,&STR_LEN,&FREQ,&MAX_X);
fu[0].equal_func();
for(int i=0;i<(int)l;i++) f[i]=i;
for(int i=1;i<=(int)m;i++){
my_shuffle(f,f+l);
fun.clear();
for(int i=0;i<(int)l;i++){
fun.push_back(f[i]);
}
fu[i]=fun;
}
for(int i=1;i<=(int)n;i++){
if(xorShift128Plus()%FREQ<=1){
ac[i]={0,(int)(xorShift128Plus()%m+1),};
}
else{
LEN=STR_LEN-(xorShift128Plus()&7);
ac[i].type=1;
for(int j=1;j<=LEN;j++){
ac[i].b.push_back(xorShift128Plus()%l+'a');
}
}
}
unsigned long long xcnt=0,nowact=1;
while(1){
if(ac[nowact].type==0){
fu[0]+=fu[ac[nowact].a];
}
else{
ans[++xcnt]=fu[0].func(ac[nowact].b);
if(xcnt==MAX_X) break;
}
nowact++;
if(nowact>n) nowact-=n;
}
unsigned long long anss=0;
for(int i=1;i<=(int)q;i++){
unsigned long long res=getHash(ans[xorShift128Plus()%MAX_X+1])-i;
anss^=res;
}
cout<<anss<<endl;
}
后记



$\large\text{老婆可爱捏}$

暑假集训CSP提高模拟8的更多相关文章
- 2015UESTC 暑假集训总结
day1: 考微观经济学去了…… day2: 一开始就看了看一道题目最短的B题,拍了半小时交了上去wa了 感觉自己一定是自己想错了,于是去拍大家都过的A题,十分钟拍完交上去就A了 然后B题写了一发暴力 ...
- 牛客网NOIP赛前集训营-提高组(第四场)游记
牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...
- 牛客网NOIP赛前集训营-提高组(第四场)B区间
牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1 \dots a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...
- STL 入门 (17 暑假集训第一周)
快速全排列的函数 头文件<algorithm> next_permutation(a,a+n) ---------------------------------------------- ...
- 牛客网NOIP赛前集训营-提高组(第四场)B题 区间
牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...
- 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告
目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...
- 20190820 Tue 集训总结&NOIP模拟 27
低谷度过了? 但是skyh阿卡了,还是反衬出我的辣鸡. T1知道要sort,却忘了判重,正解不如暴力分高,555. T2成功化出正解柿子,然后化过头了,化出了无法DP的柿子. 果然不够强,大神们一眼就 ...
- 暑假集训Day2 互不侵犯(状压dp)
这又是个状压dp (大型自闭现场) 题目大意: 在N*N的棋盘里面放K个国王,使他们互不攻击,共有多少种摆放方案.国王能攻击到它上下左右,以及左上左下右上右下八个方向上附近的各一个格子,共8个格子. ...
- 暑假集训Day1 整数划分
题目大意: 如何把一个正整数N(N长度<20)划分为M(M>=1)个部分,使这M个部分的乘积最大.N.M从键盘输入,输出最大值及一种划分方式. 输入格式: 第一行一个正整数T(T<= ...
- #10471. 「2020-10-02 提高模拟赛」灌溉 (water)
题面:#10471. 「2020-10-02 提高模拟赛」灌溉 (water) 假设只有一组询问,我们可以用二分求解:二分最大距离是多少,然后找到深度最大的结点,并且把它的\(k\)倍祖先的一整子树删 ...
随机推荐
- 学习笔记--初识Java面向对象
面向对象与面向过程的区别 面向过程:主要关注具体过程,因果关系 优点:对于业务逻辑比较简单的程序,可以得到快速开发,前期投入成本比较低 缺点:由于面向过程的使用让程序间的元素"耦合度&quo ...
- JDBC第二天:防sql攻击
1 什么是SQL攻击 在需要用户输入的地方,用户输入的是SQL语句的片段,最终用户输入的SQL片段与我们DAO中写的SQL语句合成一个完整的SQL语句!例如用户在登录时输入的用户名和密码都是为SQL语 ...
- 2023/4/17 SCRUM个人博客
1.我昨天的任务 学习了easydict库的基本操作 2.遇到了什么困难 没有找到合适的人脸识别库 3.我今天的任务 初步学习dlib的安装,了解dlib的基础组件
- fragment的查找和移除
FragmentManager fragmentmanger = getSupportFragmentManager(); FragmentTransaction fragmenttransactio ...
- ssh 转发 和 切换图形化
适用环境 宿主机连接到一台服务器是,服务器系统里面的浏览器点击http网页卡顿,那么这时可以通过ssh将端口转发到宿主机 使用宿主机的浏览器点击,则不会很卡顿. [root@foundation1 ~ ...
- 【Shiro】03 ini认证实现
[基本概念] 1.身份验证 即在应用中谁能证明他就是他本人. 一般提供如他们的身份ID 一些标识信息来表明他就是他本人,如提供身份证,用户名/密码来证明. 在 shiro 中,用户需要提供princi ...
- 美国小伙: "American Guy: Only communism can save America!"
视频地址: https://www.youtube.com/watch?v=Y_WQnXFh8ss 2024大选在即,又是拜登对阵特朗普的旧日重现.在角逐谁的对手反对者更多的畸形内耗中,有一个名为 M ...
- 【转载】 Linux 设置CPU Performance模式
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/zaf0516/article/detail ...
- 再探 游戏 《 2048 》 —— AI方法—— 缘起、缘灭(1) —— Firefox浏览器下自动运行游戏篇
四年前曾经写过一过博客: 对 游戏 < 2048 > 的一些思考 虽然过去几年了,但是这个游戏一直没有搞懂该怎么使用AI算法来进行求解,这里再次对这个问题进行一些探索. ========= ...
- 安装华为软件昇腾mindspore-gpu-1.9.0失败记录
官网安装地址: https://www.mindspore.cn/install PS: 不得不说华为的软件是愈发的不好用了,这个mindspore老版本去年我是使用过的,安装也是比较方便的,搞不清这 ...