暑假集训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\)倍祖先的一整子树删 ...
随机推荐
- 前端使用 Konva 实现可视化设计器(18)- 素材嵌套 - 加载阶段
本章主要实现素材的嵌套(加载阶段)这意味着可以拖入画布的对象,不只是图片素材,还可以是嵌套的图片和图形. 请大家动动小手,给我一个免费的 Star 吧~ 大家如果发现了 Bug,欢迎来提 Issue ...
- BeanUtils.copyProperties无法复制list对象,替换为lambda表达式
List<Setmeal> setmeals = setmealMapper.selectList(queryWrapper); List<SetmealVO>vo=new A ...
- Fiddler使用界面介绍-左侧会话面板
左侧会话面板,是Fiddler抓取的请求数据展示
- 【MybatisPlus】 Field '主键' doesn't have a default value
使用MybatisPlus的 PoMapper执行Insert插入方法报错: 复原场景: 1.PO对象存在主键值(双主键) 2.表中数据为空 3.首次插入 这张表使用的是双主键,发现原因是因为PO设置 ...
- 【Git】01 下载安装(Windows)
Git 官网地址:[点我访问] https://git-scm.com/ 点击这个电脑自动识别操作系统与系统位数 开始安装 安装的目录不要有中文就行[最好也不要有空格] 算了,直接全选[小孩子才做选择 ...
- 【JDBC】Extra03 PostgreSQL-JDBC
PostgreSQL的JDBC实现: <!-- https://mvnrepository.com/artifact/org.postgresql/postgresql --> <d ...
- Efficientvit: Enhanced linear attention for high-resolution low-computation visual recognition
GitHub地址: https://github.com/mit-han-lab/efficientvit#usage 相关: https://www.jetson-ai-lab.com/vit/tu ...
- 哈哈哈,我就说未来要研发无人的AI潜艇嘛 —— 说啥来啥 —— AI驱动的无人潜艇
相关: 沉默5个月后,美国对华发出挑战书,万没想到,中方打法早就变了
- plsql中的常用功能整理
1.关键字查找 2.保存登录密码 完美!
- vue 文件流下载
/** * 文件转为文件流 * @param {file} file //文件 */ export function getFileBlob(file) { var dataUrl va ...