暑假集训CSP提高模拟8
1.Codeforces Round 955 (Div. 2)2.AtCoder Beginner Contest 3633.AtCoder Regular Contest 182(A B C)4.暑假集训CSP提高模拟15.暑假集训CSP提高模拟26.暑假集训CSP提高模拟77.暑假集训CSP提高模拟58.暑假集训 加赛19.暑假集训CSP提高模拟410.暑假集训CSP提高模拟1811.暑假集训CSP提高模拟1712.暑假集训CSP提高模拟 1613.暑假集训CSP提高模拟 ∫[0,6] (x^2)/6 dx14.暑假集训CSP提高模拟1115.暑假集训SCP提高模拟1016.暑假集训PVZ提高模拟9
17.暑假集训CSP提高模拟8
18.暑集假训SCP提高拟模2119.[CL-FOOL] CLOI 愚人赛的部分官方题解与小杂谈20.トヨタ自動車プログラミングコンテスト2024#7(ABC 362)21.寒假集训测试2 题目转存22.HEOI2024 题目转存23.高一小学期224.张江蔡25.高一高考集训总结赛26.高一下二调题目转存27.CSP提高组模拟128.Atcoder Beginner Contest 36729.[R18][中国語翻訳]HDKのABC370赛試(ABC370)30.[30] CSP 加赛 131.[33](CSP 集训)CSP-S 模拟 432.[34](CSP 集训)CSP-S 联训模拟 133.[35] (CSP 集训) CSP-S 模拟 534.[36](CSP 集训)CSP-S 模拟 635.AtCoder Beginner Contest 37336.[37](CSP 集训)CSP-S 模拟 737.[39] (多校联训) A层冲刺NOIP2024模拟赛0138.[40](CSP 集训)CSP 联训模拟 239.[42] (多校联训) A层冲刺NOIP2024模拟赛0340.[41] (CSP 集训) CSP-S 模拟 941.[44] (多校联训) A层冲刺NOIP2024模拟赛0442.[45] (多校联训) A层冲刺NOIP2024模拟赛0543.[46] (多校联训) A层冲刺NOIP2024模拟赛0644.パナソニックグループ プログラミングコンテスト2024(ABC 375)45.[47] (CSP 集训) CSP-S 模拟 1146.[49 & 50] (多校联训) A层冲刺NOIP2024模拟赛08 | CSP-S 模拟 1247.[51] (多校联训) A层冲刺NOIP2024模拟赛0948.Atcoder Beginner Contest 37649.Codeforces Round 980 (Div. 2)50.[54] (多校联训) A层冲刺NOIP2024模拟赛1251.[57] (多校联训) A层冲刺NOIP2024模拟赛1552.[61] (多校联训) A层冲刺NOIP2024模拟赛1853.[62] (NOIP 集训) NOIP2024加赛 254.[63] (多校联训) A层冲刺NOIP2024模拟赛1955.[68] (炼石计划) NOIP 模拟赛 #2056.[68] (NOIP集训) NOIP2024 加赛 557.[72] (多校联训) A层冲刺NOIP2024模拟赛2558.[73] (NOIP集训) NOIP2024 加赛 759.[75] (NOIP集训) NOIP2024 加赛 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.容易的多元拉格朗日反演练习题
记
记一个长为
首先转化题意。条件
因此有转化后的问题:
给定整数
不妨假设
- 选择整数
,将 升序排列得到 。令 的答案为 的值。 - 最终的分数即为所有可能的
的答案中的最小值。
容易发现
#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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!