2024年GPLT团体程序设计竞赛题解(无L3-3)

2024-04-25 05:28

本文主要是介绍2024年GPLT团体程序设计竞赛题解(无L3-3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

L1-1 编程解决一切

略~~~

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e4+10;void solve(){cout<<"Problem? The Solution: Programming.";}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-2 再进去几个人

观察样例,再结合一下题意,看以得出答案为出去的人数减去进去的人数

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long longvoid solve(){int a,b;cin>>a>>b;cout<<b-a;
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-3 帮助色盲

按照题意模拟即可,赛时第一个点死活过不去,现在发现打错字母了〒▽〒

把"biii"写成了"bill",痛失3分! 没想到色盲竟是我自己?

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
//当前交通灯为红灯或绿灯时,检测其前方两米内是否有同向行走的人 —— 如果有
///如果没有,则根据灯的颜色给出不同的提示音。黄灯也不需要给出提示。void solve(){int a,b; cin>>a>>b;if(a==0){if(b==0){cout<<"biii"<<endl; //???cout<<"stop";}else{cout<<"-"<<endl;cout<<"stop";}}else if(a==1){if(b==0){cout<<"dudu"<<endl;cout<<"move";}else{cout<<"-"<<endl;cout<<"move";}}else{cout<<"-"<<endl;cout<<"stop";}}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-4 四项全能

刚开始理解错题了,其实只需要算出总数,减去会m-1项的人数,剩下的即为至少会m项的人数。

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long longvoid solve(){int n,m; cin>>n>>m;vector<int> a(m+1);int sum=0;for(int i=1;i<=m;i++){cin>>a[i]; sum+=a[i];}sum-=(m-1)*n;cout<<max(0*1LL,sum);
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-5 别再来这么多猫娘了!

有两个测试点含有替换词 的字串,这点没想到。。。

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e5+10;
int n;
string s[N],tar="<censored>";void solve(){cin>>n;for(int i=1;i<=n;i++) cin>>s[i];int k; cin>>k; getchar();string str; getline(cin,str);int cnt=0;for(int i=1;i<=n;i++){while(str.find(s[i])!=str.npos){ int pos=str.find(s[i]); //找到违禁词 cnt++;str.erase(pos,s[i].size());str.insert(pos,"***"); //替换 }}if(cnt>=k){cout<<cnt<<endl<<"He Xie Ni Quan Jia!";}else{while(str.find("***")!=-1){int pos=str.find("***");str.erase(pos,3);str.insert(pos,"<censored>");}cout<<str;}
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-6 兰州牛肉面

用一个数组记录每种牛肉面卖出多少碗

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long longvoid solve(){int n; cin>>n;vector<double> a(n+1);for(int i=1;i<=n;i++) cin>>a[i];double sum=0;vector<int> cnt(n+1);int x,y;while(cin>>x>>y,x){cnt[x]+=y;sum+=a[x]*y;}for(int i=1;i<=n;i++) cout<<cnt[i]<<endl;printf("%.2f",sum);
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-7 整数的持续性

按照题意写就行,判断每个数的持续性

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e5+10;
unordered_map<int,bool> vis;
vector<int> ans;
int maxn=0;void solve(){int a,b; cin>>a>>b;for(int i=a;i<=b;i++){if(vis[i]) continue;vis[i]=1;int cnt=0;vector<int> tmp;int k=i;while(k>=10){int x=k,sum=1;while(x){sum*=x%10;x/=10;}k=sum; cnt++;vis[k]=1;}if(cnt>maxn){ //更新答案 ans.clear();maxn=cnt;ans.push_back(i);}else if(cnt==maxn){ans.push_back(i);}}cout<<maxn<<endl;int flag=0;for(auto i:ans){if(flag) cout<<' ';cout<<i;flag++;}
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L1-8 九宫格

题目有句话是这道题的关键点**“要求 1 到 9 这九个数字中的每个数字在每一行、每一列、每个宫位中都只能出现一次”**

也就是说需要判断三个条件:

  • 在本行中该数字出现一次
  • 在本列中该数字出现一次
  • 在这个宫位该数字出现一次

当然这些数字的的范围在1—9.

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e4+10;
int a[10][10];
bool flag=true;void solve(){flag=true;for(int i=1;i<=9;i++)for(int j=1;j<=9;j++)cin>>a[i][j];for(int t=1;t<=9;t+=3){ //我们需要把这个9x9的矩阵分割成9个正方形宫位for(int p=1;p<=9;p+=3){set<int> s; //看是不是9个不同的数字//判断该宫位for(int i=t;i<=t+3-1;i++){for(int j=p;j<=p+3-1;j++){if(a[i][j]<=0||a[i][j]>9) flag=false;//数字越界了for(int k=1;k<=9;k++){if(a[i][j]==a[i][k]&&j!=k) flag=false;if(a[i][j]==a[k][j]&&i!=k) flag=false;}s.insert(a[i][j]);} }if(s.size()!=9) flag=false; }}if(flag) cout<<1<<endl;else cout<<0<<endl;}signed main(){int T=1;cin>>T;
//	IOS;while(T--){solve();} return 0;
}

至此L1结束! 时间大约用了1小时10几分钟。比自己规定的1小时,多了10来分钟。。。

感觉L2应该简单些,事实正是如此!

L2-1 鱼与熊掌

题意很好理解,但是一看范围n,m都是1e5,暴力应该会超时的

所以我先把回答存起来,离线处理!

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
#define fi first
#define se second
const int N = 1e5+10;
set<int> s[N];
int n,m;
vector<pair<int,int>> q;
int ans[N];void solve(){cin>>n>>m;for(int i=1;i<=n;i++){int k; cin>>k;for(int j=1;j<=k;j++){int x; cin>>x;s[i].insert(x);}}int k; cin>>k;for(int i=1;i<=k;i++){int l,r; cin>>l>>r;q.push_back({l,r});}for(int i=1;i<=n;i++){for(int j=0;j<k;j++){int l=q[j].fi,r=q[j].se;if(s[i].count(l)&&s[i].count(r)) ans[j+1]++;}}for(int i=1;i<=k;i++) cout<<ans[i]<<endl;
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L2-2 懂蛇语

一个简单的STL应用,题意很清楚

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e4+10;
int n,m;
map<string,vector<string>> mp;void solve(){cin>>n; getchar();for(int i=1;i<=n;i++){string s,s1,str=""; getline(cin,s);s1=s; s=" "+s;for(int j=1;j<s.size();j++){//分离出单词首字母 if(s[j-1]==' '&&s[j]!=' ') str.push_back(s[j]);}mp[str].push_back(s1);}cin>>m; getchar();for(int i=1;i<=m;i++){string s,s1,str=""; getline(cin,s);s1=s; s=" "+s;for(int j=1;j<s.size();j++){//分离出单词首字母 if(s[j-1]==' '&&s[j]!=' ') str.push_back(s[j]);}if(!mp.count(str)) cout<<s1<<endl;else{int flag=0;vector<string> tmp;for(auto i:mp[str]){tmp.push_back(i);}sort(tmp.begin(),tmp.end());for(auto i:tmp){if(flag) cout<<'|';cout<<i; flag++;}cout<<endl;}}}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L2-3 满树的遍历

树的存储的题,非常基础

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e5+10;
vector<int> tr[N];
int n,root;
int vis[N],flag=1,maxn; 
int f=0;
void dfs(int u){if(f) cout<<' ';cout<<u; f++;for(auto v:tr[u]){dfs(v);}
}void solve(){cin>>n;for(int i=1;i<=n;i++){int fa; cin>>fa;if(!fa){root=i;continue;}tr[fa].push_back(i);}for(int i=1;i<=n;i++){maxn=max(maxn,(int)tr[i].size());sort(tr[i].begin(),tr[i].end());}for(int i=1;i<=n;i++){if(tr[i].size()&&tr[i].size()!=maxn) flag=false;}cout<<maxn<<' ';if(flag) cout<<"yes"<<endl;else cout<<"no"<<endl;dfs(root);
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L2-4 吉利矩阵

想了10来分钟,是一道dfs的题加上剪枝应该能过,但是写道一半发现没什么思路,然后开L3了

https://www.cnblogs.com/cuijunjie18/p/18149439

这位大佬写的不错,思路非常清晰!


至此L2结束,此时总分166,此时时间剩余1小时不足10分钟,以为175稳了,甚至有机会拿个银…

开L3,第一题一看是个bfs的板题,以为能守铜摄银? 但是写了半个多小时发现写不下去了,应该是思路错了,最后赶紧输出特殊样例,骗了3分,此时分数169,离175还差6分,时间还有半个多小时!

现在真正的慌了,赶紧回到L1看了那几道丢分的题,发现加起来足够6分了,看看第一道丢分的题红绿灯那个,发现找不到哪错了…能找到才怪 ( ̄▽ ̄)“赛后 发现打错字了。。。把"biii” 写成了"bill" 犯了这种低级错误,痛失3分。 然后发现剩下的两道丢分的题也找不到错误…

然后写了L3的第二道,此时只有20分钟左右,抱着不拿奖的心态做了,最后贪心加双指针骗了21分,最终分数190!

L3-1 夺宝大赛

  • 从大本营出发找到所有点的最短路,也就是本题的最短时间
  • 然后看看每个队伍与其它队伍到达时间是否相同,相同就会发生火并。都不同就更新答案。
  • 然后…就没然后了,思路就是这么简单,痛失30分〒▽〒
#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
#define fi first
#define se second
const int N = 1e3+10, INF = 0x3f3f3f3f;
typedef pair<int,int> PII;
//最先到达大本营并能活着夺宝的队伍获得胜利
int m,n,k;
int dist[N][N]; //大本营到参赛队的最短距离 
int g[N][N],sx,sy;
int dx[]={0,1,0,-1};
int dy[]={1,0,-1,0};
vector<PII> arr; 
struct node{int x,y,step;
};
bool vis[N][N];void bfs(){memset(dist,INF,sizeof(dist));dist[sx][sy]=0;queue<node> q;q.push({sx,sy,0});vis[sx][sy]=1;while(q.size()){auto t=q.front(); q.pop();for(int i=0;i<4;i++){int tx=t.x+dx[i];int ty=t.y+dy[i];if(tx<1||ty<1||tx>m||ty>n) continue;if(vis[tx][ty]||g[tx][ty]==0) continue;vis[tx][ty]=1;q.push({tx,ty,t.step+1});dist[tx][ty]=t.step+1;}}
}void solve(){cin>>m>>n;for(int i=1;i<=m;i++){for(int j=1;j<=n;j++){cin>>g[i][j];if(g[i][j]==2) sx=i,sy=j; //大本营 }} bfs();cin>>k;for(int i=0;i<k;i++){int x,y; cin>>y>>x;arr.push_back({x,y});} int id=-1,res=INF;for(int i=0;i<k;i++){int flag=1,now=dist[arr[i].fi][arr[i].se];for(int j=0;j<k;j++){if(i==j) continue;if(dist[arr[i].fi][arr[i].se]==dist[arr[j].fi][arr[j].se]) flag=0;}if(flag&&dist[arr[i].fi][arr[i].se]<res){res=dist[arr[i].fi][arr[i].se];id=i+1;}}if(id!=-1) cout<<id<<' '<<res;else cout<<"No winner.";
}signed main(){int T=1;
//	cin>>T;
//	IOS;while(T--){solve();} return 0;
}

L3-2 工业园区建设

贪心加双指针骗分,有两个点超时,21分

#include<bits/stdc++.h>
using namespace std;#define IOS ios::sync_stdio(0),cin.tie(0),cout.tie(0)
#define endl '\n'
#define int long long
const int N = 1e4+10;void solve(){int n,m,k;cin>>n>>m>>k;string s; cin>>s;s=" "+s;vector<int> a(n+1);int flag=0;for(int i=1;i<=n;i++){int l=i-1,r=i+1,cnt=0,sum=0,t=m;if(s[i]=='1') cnt++;else if(t>0){t--; cnt++;}while(l>0||r<=n){if(cnt==k) break;if(l>0&&s[l]=='1') cnt++,sum+=(i-l);else if(t>0&&l>0){t--; cnt++; sum+=(i-l);}if(cnt==k) break;if(r<=n&&s[r]=='1') cnt++,sum+=(r-i); else if(t>0&&r<=n){t--; cnt++; sum+=(r-i);}if(cnt==k) break;l--,r++;}if(flag) cout<<' ';cout<<sum; flag++;}cout<<endl;
}signed main(){int T=1;cin>>T;
//	IOS;while(T--){solve();} return 0;
}

总结

相比去年的90多分今年还是有进步的。

L1部分前面写的不太顺利,后面几道题目比较好理解。

L2部分的前三道相比以往简单许多,第四道是一道dfs+剪枝的题,也一道剪枝的基础题,奈何实力太弱,虽然看出来了,但是对于矩阵的搜索还是不太熟练,写到一半写不下去了( ̄▽ ̄)"

至于L3吗,前两道题相比以往简单许多,第一题是一道bfs的题,比较模板,赛时的以为能切掉,还是高估自己了,应该先把题读明白了再写,不能想到哪是哪,对吧?写到最后自己都迷糊了,赛后补了一下该题,发现确实是到很基础的bfs,之前白做这么多bfs的题了〒▽〒 关于L3的第二题,面向样例的编程。。。

这篇关于2024年GPLT团体程序设计竞赛题解(无L3-3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933792

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?id=KS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的,这引发了人们的担忧和猜测,即它们可能已

轻松录制每一刻:探索2024年免费高清录屏应用

你不会还在用一些社交工具来录屏吧?现在的市面上有不少免费录屏的软件了。别看如软件是免费的,它的功能比起社交工具的录屏功能来说全面的多。这次我就分享几款我用过的录屏工具。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  这个软件的操作方式非常简单,打开软件之后从界面设计就能看出来这个软件操作的便捷性。界面的设计简单明了基本一打眼你就会轻松驾驭啦

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松