暑假集训CSP提高模拟 ∫[0,6] (x^2)/6 dx
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提高模拟 16
13.暑假集训CSP提高模拟 ∫[0,6] (x^2)/6 dx
14.暑假集训CSP提高模拟1115.暑假集训SCP提高模拟1016.暑假集训PVZ提高模拟917.暑假集训CSP提高模拟818.暑集假训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;
#define int long long
const int p=1e9+7;
signed main(){
// freopen("T1.in","r",stdin);
// freopen("test.out","w",stdout);
int a,b,c,d,ans=0;
scanf("%lld %lld %lld %lld",&a,&b,&c,&d);
for(int i=1;i<=999;++i){
for(int j=1;j<=999-i;++j){
if(__gcd(i,j)==1){
int l1=ceil(a*1.0/i),l2=ceil(c*1.0/j);
int r1=floor(b*1.0/i),r2=floor(d*1.0/j);
ans=(((i+j)*max(0ll,(min(r1,r2)-max(l1,l2)+1))%p)+ans)%p;
// if(min(r1,r2)-max(l1,l2)>0)
// cout<<i<<" "<<j<<" "<<max(l1,l2)<<" "<<min(r1,r2)<<" "<<endl;
}
}
}
printf("%lld\n",ans);
}
B.密码技术
你说得对但是这题我做过😢
注意到交换具有传递性,对
1 2 3 3
2 -> 1 -> 1 -> 2
3 3 2 1
多摸几组可以得到规律:这样的交换是有传递性的,每当我们想交换两个不能直接交换的元素,仅仅需要以中间元素作为中介分别交换即可.
因为这个题元素不重复(话说当时发现元素重复的这个题在同阶范围下是不可做的)因此行和列交换互不影响,直接乘法原理乘一下就行了. 对于每一个能互相交换的连通块,不妨用并查集维护大小
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,K;
int a[51][51];
const int p=998244353;
class dsu{
private:
int fa[51],size[51];
public:
void clear(){
for(int i=1;i<=n;++i){
fa[i]=i;
size[i]=1;
}
}
int find(int id){
if(id==fa[id]) return id;
fa[id]=find(fa[id]);
return fa[id];
}
void join(int x,int y){
int a=find(x),b=find(y);
if(a!=b){
fa[a]=b;
size[b]+=size[a];
size[a]=0;
}
}
bool isfa(int id){
return id==fa[id];
}
int get_size(int id){
return size[id];
}
};
dsu h,l;
int frac[51];
signed main(){
// freopen("T2.in","r",stdin);
frac[0]=1;
for(int i=1;i<=50;++i){
frac[i]=frac[i-1]*i%p;
}
scanf("%lld %lld",&n,&K);
for(int i=1;i<=n;++i){
for(int j=1;j<=n;++j){
scanf("%lld",&a[i][j]);
}
}
h.clear();l.clear();
for(int i=1;i<=n;++i){
for(int j=i+1;j<=n;++j){
bool flag=true;
for(int k=1;k<=n;++k){
if(a[i][k]+a[j][k]>K){
flag=false;break;
}
}
if(flag) h.join(i,j);
}
}
for(int i=1;i<=n;++i){
for(int j=i+1;j<=n;++j){
bool flag=true;
for(int k=1;k<=n;++k){
if(a[k][i]+a[k][j]>K){
flag=false;break;
}
}
if(flag) l.join(i,j);
}
}
int ans=1;
for(int i=1;i<=n;++i){
if(h.isfa(i)){
ans=ans*frac[h.get_size(i)]%p;
}
if(l.isfa(i)){
ans=ans*frac[l.get_size(i)]%p;
}
}
printf("%lld\n",ans);
}
C.修水管
暴力做法是显然的,写一个深搜暴力转移即可(其实能写状压的,我怎么老是忘了能状压)
#include<bits/stdc++.h>
using namespace std;
#define double long double
int n,r;
int w[251];
double p[251];
double dfs(int now,int brok,double nowp){
double res=0;
if(now>r){ return 0;}
if(nowp==0){ return 0;}
double zc=0;if(brok){ res+=w[brok];zc=p[brok];p[brok]=0;}
double nwp=1;
for(int i=1;i<=n;++i){
res+=dfs(now+1,i,nwp*p[i]);
nwp*=(1-p[i]);
}
res+=dfs(now+1,0,nwp);
if(brok){ p[brok]=zc;}
return res*nowp;
}
int main(){
int cases;cin>>cases;while(cases--){
cin>>n>>r;
for(int i=1;i<=n;++i){
cin>>p[i]>>w[i];
}
printf("%.10Lf\n",dfs(0,0,1));
}
}
这道题的正解是 DP,设计
要得出转移,必须要知道第
所以有:
最后概率乘权值即可.
#include<bits/stdc++.h>
using namespace std;
int n,r;
double ans,p[251],w[251],f[251][251];
int main(){
int cases;scanf("%d",&cases);while(cases--){
scanf("%d %d",&n,&r);
for(int i=1;i<=n;++i){
scanf("%lf %lf",&p[i],&w[i]);
}
memset(f,0,sizeof f);
ans=0;
f[0][0]=1;
double res=0;
for(int i=0;i<=n-1;++i){
for(int j=0;j<=(i<r?i:r);++j){
res=pow(1-p[i+1],r-j);
f[i+1][j]+=f[i][j]*res;
if(j<r){
f[i+1][j+1]+=f[i][j]*(1-res);
ans+=f[i][j]*(1-res)*w[i+1];
}
}
}
printf("%.10lf\n",ans);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!