首页 > 其他分享 >暑假集训csp提高模拟4

暑假集训csp提高模拟4

时间:2024-08-19 19:04:46浏览次数:15  
标签:暑假 int freopen long 集训 FILE using csp define

赛时 rank43,T1 100,T2 31,T3 0,T4 9

T2 由于学校机子的O2跑的还没有本地的O1快(太快啦!!!),挂了40pts

T4 暴力没有取模和特判,挂了5pts

与和

[ABC238D] AND and SUM

签到题

由于\(x\&y=a\),所以有\(x+y=s\ge2*a\)

考虑二进制下的加法,如果有一个\(sth\)满足\(a*2+sth=s\),那么\(sth\&a\)一定为0。

将\(s-a*2\)的二进制表示出来,与\(a\)按位与,如果不为0,那么就为No,反之为Yes。

注意特判\(s-2*a<0\)的情况,此时答案一定为No。

点此查看代码
#include<bits/stdc++.h>
#include<bits/extc++.h>
// using namespace __gnu_pbds;
// using namespace __gnu_cxx;
using namespace std;
#define infile(x) freopen(x,"r",stdin)
#define outfile(x) freopen(x,"w",stdout)
#define errfile(x) freopen(x,"w",stderr)
#ifdef LOCAL
    FILE *InFile = infile("in.in"),*OutFile = outfile("out.out");
    // FILE *ErrFile=errfile("err.err");
#else
    FILE *Infile = stdin,*OutFile = stdout;
    //FILE *ErrFile = stderr;
#endif
using ll=long long;using ull=unsigned long long;
using db = double;using ldb = long double;
inline void solve(){
    int T;cin>>T;
    while(T--){
        ll a,s;
        cin>>a>>s;
        ll c = s-a*2;
        if(c < 0){cout<<"No\n";continue;}
        bool flag = c&a;
        cout<<(flag?"No\n":"Yes\n");
    }
}
signed main(){
    cin.tie(nullptr)->sync_with_stdio(false);
    cout.tie(nullptr)->sync_with_stdio(false);
    solve();  
}

函数

[ABC366F] Maximum Composition

赛时将输入random_shuffle了

然后赛后试了试,卡了卡时,学校oj可以拿97,AT上WA一个

有模拟退火+卡时过的,正解是推柿子。

如果\(f_1(f_2(x))>f_2(f_1(x))\),那么有\(A_1A_2x+A_1B_2+B_1>A_2A_1x+A_2B_1+B_2\)

再推一下,就有\(B_2(A_1-1)>B_1(A_2-1)\),然后还有\(\frac{B_2}{A_2-1}>\frac{B_1}{A_1-1}\)

按照\(\frac{B}{A-1}\)降序排列,写个\(O(nk)\)的背包就过了。

时间复杂度\(O(nk+n\log n)\)

点此查看代码
#include<bits/stdc++.h>
#include<bits/extc++.h>
// using namespace __gnu_pbds;
// using namespace __gnu_cxx;
using namespace std;
#define infile(x) freopen(x,"r",stdin)
#define outfile(x) freopen(x,"w",stdout)
#define errfile(x) freopen(x,"w",stderr)
#ifdef LOCAL
    FILE *InFile = infile("in.in"),*OutFile = outfile("out.out");
    // FILE *ErrFile=errfile("err.err");
#else
    FILE *Infile = stdin,*OutFile = stdout;
    //FILE *ErrFile = stderr;
#endif
using ll=long long;using ull=unsigned long long;
using db = double;using ldb = long double;
const int N = 2e5 + 10;
struct node{int a,b,id;}a[N];
int n,k;
ll f[20];
inline void solve(){
    cin>>n>>k;
    for(int i = 1;i <= n; ++i){
        cin>>a[i].a>>a[i].b;
        a[i].id = i;
    }
    ll res = 0;
    sort(a+1,a+1+n,[](node x,node y){return 1.0*x.b/(x.a-1) > 1.0*y.b/(y.a-1);});
    for(int j = 0;j <= k; ++j)f[j] = 1;
    for(int i = 1;i <= n; ++i){
        for(int j = k;j >= 1; --j){
            f[j] = max(f[j],a[i].a*f[j-1]+a[i].b);
        }
    }
    cout<<f[k];
}
signed main(){
    cin.tie(nullptr)->sync_with_stdio(false);
    cout.tie(nullptr)->sync_with_stdio(false);
    solve();
    
}

袋鼠

[CEOI2016] kangaroo

预设型dp

考虑转化题意,就是一个1n的排列,满足s为第一位,t为最后一位,对于第2n-1位,两边的数同时大于或小于它的方案数。

设\(f_{i,j}\)表示已经将前i个数,分成了j段的方案数。

对于当前枚举到的数\(i\)摆放的位置进行分讨。

  1. 新开一段 :

因为后面加的数一定比\(i\)大,所以以后插在\(i\)两边的数一定合法,插入前有\(j-1\)段,有j个空可以放。

但如果\(i>s\)则头不能放,如果\(i>t\)则尾不能放。

所以有

\[f_{i,j}=(j-[i>s]-[i>t])\times f_{i-1,j-1} \]

  1. 接在某一段的头或者尾

不合法

  1. 将两段连起来

上一步有\(j-1\)段,有\(j\)个空可以插。

所以有

\[f_{i,j}=j\times f_{i-1,j+1} \]

  1. 对于s,t的特殊处理

只可能插在最前面或最后面,要么是自己新开了一段,要么接在某一段头部或尾部

所以有

\[f_{i,j}=f_{i-1,j-1}+f_{i-1,j} \]

目标为\(f_{n,1}\),初始状态为\(f_{1,1}=1\)

点此查看代码
#include<bits/stdc++.h>
#include<bits/extc++.h>
// using namespace __gnu_pbds;
// using namespace __gnu_cxx;
using namespace std;
#define infile(x) freopen(x,"r",stdin)
#define outfile(x) freopen(x,"w",stdout)
#define errfile(x) freopen(x,"w",stderr)
#ifdef LOCAL
    FILE *InFile = infile("in.in"),*OutFile = outfile("out.out");
    // FILE *ErrFile=errfile("err.err");
#else
    FILE *Infile = stdin,*OutFile = stdout;
    //FILE *ErrFile = stderr;
#endif
using ll=long long;using ull=unsigned long long;
using db = double;using ldb = long double;
const int N = 2e3 + 10,mod = 1e9 + 7;
int n,s,t,f[N][N];
inline void solve(){
    cin>>n>>s>>t;
    f[1][1] = 1;
    for(int i = 2;i <= n; ++i){
        for(int j = 1;j <= i; ++j){
            if(s != i && t != i)
                f[i][j] = (1ll*j*f[i-1][j+1]%mod + 1ll*(j-(i>s)-(i>t))*f[i-1][j-1]%mod)%mod;
            else f[i][j] = (f[i-1][j-1] + f[i-1][j])%mod;
        }
    }
    cout<<f[n][1];
}
signed main(){
    cin.tie(nullptr)->sync_with_stdio(false);
    cout.tie(nullptr)->sync_with_stdio(false);
    solve();
}

最短路

题目不难,放个*3000不算难吧

The Classic Problem

不会写,以后有能力做vjudge题单时再写

挂个标签 : 可持久化线段树,hash,最短路

标签:暑假,int,freopen,long,集训,FILE,using,csp,define
From: https://www.cnblogs.com/hzoi-Cu/p/18367925

相关文章

  • 2024暑假集训测试28
    前言比赛链接。上午要输液所以没有打,就下午改一改,应该明天就能回去了。T1与和原题:[ABC238D]ANDandSUM。\(x\&y=a\),说明\(x,y\)二进制中都包含\(a\)且其余位上均不重合,故此若\((s-2a)\&a=0\)即符合,特殊的,因为\(x\&y=a\le\min(x,y)\),所以\(x+y=s\ge2a\),需要......
  • 【题解】Solution Set - NOIP2024集训Day10 树的直径、重⼼、中⼼
    【题解】SolutionSet-NOIP2024集训Day10树的直径、重⼼、中⼼https://www.becoder.com.cn/contest/5464「CF516D」DrazilandMorningExercise首先,我们可以换根求出所有点的\(f\)。然后不会了……思考一下,一条直径提供的到底时什么。实际上,一条直径上的点取到\(f\)......
  • 暑假集训CSP提高模拟24
    暑假集训CSP提高模拟24\(T1\)P268.与和\(100pts\)原题:[ABC238D]ANDandSUM\(x,y\)下界显然为\(a\),不妨让\(y=a,x=s-a\)然后进行\(check\)。正确性由下一种做法可以进一步推导。点击查看代码intmain(){ freopen("and.in","r",stdin); freopen("and.out"......
  • hbu2024暑假进阶训练营开营测试
    目录7-1考试成绩7-2心理阴影面积7-1考试成绩题目RainSure同学在参加一场面试,一共有n道题目,他的初始分数为m分。RainSure回答错一道题目就会扣一分,但是分数不会小于0;回答正确一道题目就会加一分。给定一个长度为n的字符串,第i个字符如果为o,代表第i道题目RainSur......
  • 2024.8.18 周总结(上周天到这周六集训,这周天放假)
    感觉这一周上难度了,尤其没听懂的是二分图和博弈论那天上午休息完之后的部分。有复习,有新知识,收获还是比较大的。晚上打游戏打多了。文化课没学多少。中午看番、玩寝室楼下桌上的游戏去了,因为寝室要关灯拉窗帘睡得也更早,一周就只写了一点点字帖,看了一点点《乡土中国》。综......
  • CCSP-ASA防火墙-05
    设置启动文件bootsystemfalsh:/pix-701.binshowbootvar(启动环境变量,查看从哪里启动)hostnameinterfacenameifipaddresssecurity-levelspeedduplexnoshutdownnat-control/nonat-controlnatglobalroutepix接口设置自动获取ip地址.inte1ipadddhcpsetrou......
  • CCSP-ASA防火墙-06
    name10.1.1.2r1(作解析)pingr1names(开启解析)nonames(关系解析)showmemory(查看内存)showcpu(查看cpu)showipaddress(查看接口地址)clockset21:0:0jul232003clocktimezoneGMT+8ntp配置fw1(config)#ntpauthentication-key1234md5cisco123fw1(conf......
  • [赛记] 暑假集训CSP提高模拟23
    进击的巨人100pts这题赛时10min打的$\Theta(n^2)$暴力然后过了,而且还是首A;正解当然不是暴力,而是要推式子;不难发现,每个$0$会原序列分割成两个互不相同的子序列,且两部分互不影响,于是我们可以分开考虑;对于一个不包含$0$的一个极大子序列,设其最左区间左端点下标为$......
  • CSP-J/S2023游记
    过了将近一年才回来补游记比赛前Day-22光速报名Day-21~0国庆假期+痛苦的whkDay1CSP-J早上乘出租车风驰电掣赶到连大,在门口等半天发现已经可以进去了。一路踩着爆浆的银杏到了日新楼门口,看到由无数人头组成的一片乌云,以及一辆挂着横幅的黄色校车。CL排场挺大进了考场,......
  • 【动态规划、dp】[CSP-J 2022] 上升点列 题解
    题目描述在一个二维平面内,给定nnn个整数点(xi......