首页 > 其他分享 >2023 GDCPC 广东省赛 ACDIK

2023 GDCPC 广东省赛 ACDIK

时间:2023-10-24 17:13:56浏览次数:43  
标签:ACDIK const GDCPC int ll cin long 2023 return

The 2023 Guangdong Provincial Collegiate Programming Contest ACDIK

去年打了这场,当时没有补题,现在来直面恐惧。

A. Programming Contest

思路:签到

// AC one more times
// nndbk
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 2e5 + 10;
int a[N];
int main()
{
    ios::sync_with_stdio(false);   cin.tie(nullptr), cout.tie(nullptr);
    
    int t; cin>>t;
    while(t--)
    {
        int y1; cin>>y1;
        int n; cin>>n;
        for(int i = 1;i <= n; i++)
            cin>>a[i];
        int y2; cin>>y2;
        ll ans = y2-y1+1;
        for(int i = 1;i <= n; i++)
        {
            if(a[i]>=y1&&a[i]<=y2)ans--;
        }
        cout<<ans<<"\n";
    }
    return 0;
}

C. Trading

思路:排序+双指针

按照价格从大到小排序,从便宜的买入从贵的卖出,做一个双指针即可。

// AC one more times
// nndbk
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 2e6 + 10;
array<int,2>a[N];
int main()
{
    ios::sync_with_stdio(false);   cin.tie(nullptr), cout.tie(nullptr);
    int t; cin>>t;
    while(t--)
    {
        int n; cin>>n;
        for(int i = 1;i <= n; i++)
            cin>>a[i][0]>>a[i][1];
        sort(a+1,a+1+n);
        int l = 1,r = n;
        ll ans = 0;
        while(l<r)
        {
            int mn = min(a[l][1],a[r][1]);
            ans += 1ll*(a[r][0]-a[l][0])*mn;
            a[l][1] -= mn;
            a[r][1] -= mn;
            if(a[l][1]==0)l++;
            if(a[r][1]==0)r--;  
        }
        cout<<ans<<"\n";
    }


    return 0;
}

D. New Houses

思路:就是这个题!明明思路就是对滴,当时赛时没写出啊。

考虑\(i\)个人有邻居的最大值,注意可能所有人都没有邻居(2*n-1<=m)。每次让没有邻居的变成有邻居的,增加的是差值。

注意特判。

// AC one more times
// nndbk
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 2e5 + 10;
array<ll,2>a[N];
ll d[N];

bool cmp(ll a,ll b)
{
    return a>b;
}
int main()
{
    ios::sync_with_stdio(false);   cin.tie(nullptr), cout.tie(nullptr);
    int t; cin >> t;
    while(t--)
    {
        int n,m; cin>>n>>m;
        ll ans = 0;
        ll hav = 0,no = 0;
        for(int i = 1;i <= n; i++)
        {
             cin>>a[i][0]>>a[i][1];
             hav += a[i][0],no += a[i][1];
             d[i] = a[i][0]-a[i][1];
        }
        if(n==1)
        {
            cout<<a[1][1]<<"\n";
            continue;
        }
        if(n==m)
        {
            cout<<hav<<"\n";
            continue;
        }

        sort(d+1,d+1+n,cmp);
        //k个人有邻居,剩下的没有邻居:需要k+2(n-k) = 2n-k个房子

        if(m>=2*n-1)//所有人都没有邻居
            ans = no;
        ll now = no;
        now += d[1];
        for(int i = 2;i <= n; i++)//i个人有邻居
        {
            now += d[i];
            if(2*n-i<=m)ans = max(ans,now);
        }   
        cout<<ans<<"\n";
    }


    return 0;
}

I. Path Planning

思路:考虑,当前的mex值由什么决定?是由当前没出现过的最小的决定。如果当前的最小值是x,那么<x的值一定都被取到了。我们可以考虑二分答案。但是问题又来了,怎么去check答案?由于我们只能往下和往右走,我们走出来的路径一定是呈现阶梯状的。

![image-20231024165435446](C:\Users\Zhou Yanan\AppData\Roaming\Typora\typora-user-images\image-20231024165435446.png)

比如上图这样一个行驶路线,我们观察每一行,上一行的有边界一定<=这一行的左边界。那么依据这个做check即可。

// AC one more times
// nndbk
#include <bits/stdc++.h>
// #define ll int
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 2e6 + 10;
int a[N];
int main()
{
    ios::sync_with_stdio(false);   cin.tie(nullptr), cout.tie(nullptr);
    int t; cin>>t;
    while(t--)
    {
        int n,m; 
        cin>>n>>m;
       // vector<vector<ll>> a(m+10, vector<ll>(n+10));
        for(int i = 1; i <= n; i++)
            for(int j = 1;j <= m; j++)
                cin>>a[i*m+j];

        auto judge = [&](ll x)
        {
            //<x都要取到
            ll l = 0,r = 0;
            for(int i = 1;i <= n; i++)
            {
                bool st = false;
                ll tl = -1,tr = -1;
                for(int j = 1;j <= m; j++)
                {
                    if(a[i*m+j]<x&&!st)
                        tl = j,st = true;
                    if(a[i*m+j]<x&&st)
                        tr = j;
                }
                if(tl==-1)continue;
                if(tl>=r)
                    l = tl,r = tr;
                else return false;
            }
            return true;
        };

        ll l = 0,r = n*m;
        while(l<=r)
        {
            ll mid = (l+r)>>1;
            if(judge(mid))l = mid+1;
            else r = mid-1;
        }
        cout<<l-1<<"\n";
    }


    return 0;
}

K. Peg Solitaire

思路:数据范围很小,直接暴搜。注意初始化!

// AC one more times
// nndbk
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 1e9 + 7;
const int N = 10;
int a[N][N];
                // 上    下     左     右
int dir[4][2] = {{-2,0},{2,0},{0,-2},{0,2}};
int n,m,k; 
bool vaild(int op ,int x,int y)
{
    if(op==0){//上
        if(x-2>=1&&a[x][y]&&a[x-1][y]&&!a[x-2][y])
            return true;
        else return false;
    }else if(op==1){
        if(x+2<=n&&a[x][y]&&a[x+1][y]&&!a[x+2][y])
            return true;
        else return false;
    }else if(op==2){
        if(y-2>=1&&a[x][y]&&a[x][y-1]&&!a[x][y-2])
            return true;
        else return false;
    }else{
        if(y+2<=m&&a[x][y]&&a[x][y+1]&&!a[x][y+2])
            return true;
        else return false;
    }
}


int ans;
void dfs(int now)
{
    ans = min(ans,now);
    for(int i = 1;i <= n; i++)
        for(int j = 1;j <= m; j++)if(a[i][j]==1){
            for(int d = 0;d < 4; d++)if(vaild(d,i,j)){
                    int x = i,y = j,op = d;
                    if(op==0){//上
                    a[x][y] = 0,a[x-1][y] = 0,a[x-2][y] = 1;
                    dfs(now-1);
                    a[x][y] = 1,a[x-1][y] = 1,a[x-2][y] = 0;

                }else if(op==1){
                    a[x][y] = 0,a[x+1][y] = 0,a[x+2][y] = 1;
                    dfs(now-1);
                    a[x][y] = 1,a[x+1][y] = 1,a[x+2][y] = 0;

                }else if(op==2){
                    a[x][y] = 0,a[x][y-1] = 0,a[x][y-2] = 1;
                    dfs(now-1);
                    a[x][y] = 1,a[x][y-1] = 1,a[x][y-2] = 0;

                }else{
                    a[x][y] = 0,a[x][y+1] = 0,a[x][y+2] = 1;
                    dfs(now-1);
                    a[x][y] = 1,a[x][y+1] = 1,a[x][y+2] = 0;
                }
            }
        }
}

void solve()
{
    cin>>n>>m>>k;
    memset(a,0,sizeof(a));
    for(int i = 1;i <= k; i++)
    {
        int x,y; cin>>x>>y;
        a[x][y] = 1;
    }

    ans = k; dfs(k);
    cout<<ans<<"\n";
}

int main()
{
    ios::sync_with_stdio(false);   cin.tie(nullptr), cout.tie(nullptr);
    int t; cin>>t;
    while(t--)
    {
        solve();
    }


    return 0;
}

标签:ACDIK,const,GDCPC,int,ll,cin,long,2023,return
From: https://www.cnblogs.com/nannandbk/p/17785251.html

相关文章

  • CSP-S 2023 题解
    CSP-S2023题解游记打得非常烂。。。也是一个经验的总结吧:T1.密码锁(lock)似乎也没什么好讲的,直接模拟枚举每一种情况即可。放上我的考场代码。#include<bits/stdc++.h>usingnamespacestd;intn,a[10][8],b[2][90][8],ans=0,len,l;intread(){intx=0,f=1;char......
  • CSP2023冬眠记
    书接上回day-16吃饭睡觉拜bot。day-15吃饭睡觉拜bot。day-14吃饭睡觉拜bot。day-13吃饭睡觉拜bot。day-12吃饭睡觉拜bot。day-11吃饭睡觉拜bot。day-10吃饭睡觉拜bot。day-9在学校OJ打上榜首。day-8被HB模拟赛偷袭,不会T1,掉下榜首。并获得成就【你不......
  • FSCTF 2023(公开赛道)WP
    FSCTF2023ID:Mar10Rank:6总结:下次看到不正常报错一定重新安装一遍工具~~web源码!启动!就在源码注释里<!--师傅们,欢迎来到CTF的世界~NSSCTF{59a1d387-6eb8-40d0-828d-99ce32b3feb8}--->webshell是啥捏哭脸是passthru,那直接命令执行Hello,you源码有注释......
  • 每日总结20231024
    代码时间(包括上课)6h代码量(行):100行博客数量(篇):1篇相关事项:1、今天是周二,今天上午上的是大型数据库应用技术和习概,大型数据库应用技术讲的是spark的相关知识,习概课讲的是党的领导的种种优势。2、今天下午上的是软件需求案例分析,这节课还是上机课,然后写的是大作业,农作物籽粒的进......
  • 2023NOIP A层联测16 T3 货物运输
    2023NOIPA层联测16T3货物运输题目描述说这是一个仙人掌图,通常将问题转换为环和树的问题在使用圆方树来解决。树解法令\(a_i=s_i-\frac{\sums_i}{n}\),最终令\(a_i=0\)。通过树形dp,从叶子节点向上转移,叶子节点要么向父亲拿资源,要么向父亲传资源,所以转移为:\[a_{fa}+=a_i......
  • 2023-10-24 Too many re-renders. React limits the number of renders to prevent an
    React报错:Toomanyre-renders.Reactlimitsthenumberofrenderstopreventaninfiniteloop. 重新渲染过多。React限制渲染次数,以防止出现无限循环。解决方案:查看你最近写的代码,比如我写了一个函数组件,我在函数组件里面写了直接执行的任务,这将导致状态变化,react会重新渲......
  • CSP-S2023游寄
    补个游记。day0前往秦皇岛,路上颓废,打半天地灵殿N打不过,一直卡在小五。不过顺便打通了非想天则N。day1上午复习了一些板子。下午考试。T1一看范围,爆搜题。但一开始读错题了,开场大概40分钟才做完。然后开始做T2,嗯?范围\(2\times10^6\),CCF应该不会出什么卡常题吧,感觉正解应......
  • 2023级HAUT新生周赛题解汇总
    2023级HAUT新生周赛(零)熟悉周赛规则专场:2023级HAUT新生周赛(一)@21级学长专场(张子豪,张鑫,李昊阳):2023级HAUT新生周赛(二)@曹瑞峰专场:2023级HAUT新生周赛(三)@22级学姐专场(杨焱,刘振歌,周欣滢):2023级HAUT新生周赛(四)@牛浩然专场:2023级HAUT新生周赛(五)@陈兰锴专场:......
  • 2023 年华中科技大学程序设计竞赛新生赛
    2023年华中科技大学程序设计竞赛新生赛P9774[HUSTFC2023]新取模运算-洛谷|计算机科学教育新生态(luogu.com.cn)\(n!\%p\),易知\(1\simn\%p\)为\(1,2,3\dotsp-1,0,1,2\dots\),所以我们可以预处理出\(1\simp-1\)的阶乘,那么答案就是\((p-1)!^{\frac{n}{p}}\t......
  • 名人名言_20230901-
    日常学习名人名言,激励自己......