暑假集训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面试一日一题:mysql执行delete数据真的被删除了吗
问题:请讲下mysql执行了delete操作,数据真的被删除了吗 分析:这个问题考察对mysql底层存储的理解. 回答要点: 主要从以下几点去考虑, 1.肯定没有真正删除? 2.为什么这样设计? my ...
- lombok到底都用来做什么
前言:我使用lombok一般都是用在实体类的外面写个@data省得写getsettostring方法,今天详细了解一下关于lombok的有一些实用技巧 @Cleanup //用于IO流的关闭,给局部变 ...
- cpu亲和性相关函数和宏 基础讲解[cpu_set_t]
cpu亲和性相关函数和宏讲解: 写在前面: 我在查找关于linux cpu宏函数没看到有对宏函数基础的.详细的讲解,笔者便通过官方文档入手,对次进行的翻译和理解希望能帮到对这方面宏有疑惑的读者 exp ...
- 【AJAX】Asynchronous JavaScript And XML (非同步的JS & XML)
什么是AJAX? 按照使用的感觉来看 说到底就是一个可以不刷新网页就能发送POST & GET请求的技术 AJAX 即"Asynchronous Javascript And XML ...
- Google在放弃Tensorflow后推出Google版本的Pytorch框架 —— Jax
相关: 谷歌放弃TensorFlow了 虽然在某种上来说,Google已经放弃了Tensorflow框架,但是由于Tensorflow的历史地位所造成的遗留应用,因此Tensorflow框架已经处于维 ...
- 伪代码中ties broken arbitrarily是什么含义?
最近在看一个物联网的论文,论文的伪代码中有这么一个地方标有:ties broken arbitrarily,对这个写法有些搞不清楚含义,于是网上找到了下面的资料: https://www.zhihu. ...
- ubuntu20.04/22.04 系统环境下源码编译Python3.10
2022年10月3日更新 在Ubuntu22.04系统上源码编译python,所依赖环境的安装命令为: sudo apt install gcc g++ libffi-dev build-essent ...
- C# ?. 判斷Null值
有一句代碼: @Html.DisplayFor(modelItem => item.SellDate, "RegularDate") RegularDate.cshtml 內 ...
- 将整个工程的GBK转为utf-8格式
eclipse将整个工程转为utf-8时原先中文注释会变为乱码,13年时写了个脚本将整个文件的java以及配置文件转为utf-8格式,下面是代码 package com.code.pd; import ...
- PHP中的Malformed UTF-8 characters错误解决
在PHP开发中,开发者经常会遇到Malformed UTF-8 characters错误.这个错误通常是由于代码中存在无效的UTF-8字符而引起的.本篇博客将为您介绍如何解决这个问题. 什么是UTF- ...