西安理工大学2024年程序设计校赛(校外同步赛)(ABCGIL)

2024-03-18 02:28

本文主要是介绍西安理工大学2024年程序设计校赛(校外同步赛)(ABCGIL),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

比赛地址传送门

A.签到篇-上

#include <bits/stdc++.h>
using namespace std;
int main()
{string str;cin>>str;if(str=="A"||str=="B"||str=="C") cout<<"YES"<<'\n';else cout<<"NO"<<'\n';return 0;
}

B.签到篇-中

#include <bits/stdc++.h>
using namespace std;
const string name[]={"Eagle","Pigeons","People","Cow","Fleas","Caterpillar","Leeches","Worms"
};
int main()
{string a,b,c;getline(cin,a),getline(cin,b),getline(cin,c);int result=1;if(a[0]=='I') result+=4;if(b[0]=='M'||b[0]=='W') result+=2;if((result==3&&c[1]=='e')||(result!=3&&c[0]=='H')) result++;cout<<name[result-1]<<'\n';return 0;
}

C.签到篇-下

当x、y、z相等时 a、b相等,否则一定有 a > b

#include <bits/stdc++.h>
using namespace std;
typedef long double ld;
int main()
{string a,b,c;cin>>a>>b>>c;if(a==b&&b==c) cout<<"=";else cout<<'>';return 0;
}

G.数字查询

典型数位dp,在求解之前维护一个数组 d p [ i ] [ j ] dp[i][j] dp[i][j] 表示一个 i 位的数字且第 i 位上的数字是 j 的满足要求的数的个数(注意 j 的取值为 [ 0 , 9 ] [0,9] [0,9]),递推公式为

dp[i][j] = dp[i-1][j-2] + dp[i-1][j+2]
随后开始求解 y 以内的答案,假设 y 的各位数字为 abcde...,那么对于位数等于 y 的所有数字,答案中一定包括从 0 到 a-1xxxxxx 区间中满足要求的数字的个数,对于位数小于 y 的数字,答案中一定包括最高位为 0 到 9 的该位数的所有情况

例如,y = 427 时,对于位数为 3 的所有数字,答案中一定包括 [ 100 , 200 ) , [ 200 , 300 ) , [ 300 , 400 ) [100,200),[200,300),[300,400) [100,200),[200,300),[300,400)中所有满足要求的数字的个数(此处为什么没有 [ 0 , 100 ) [0,100) [0,100)区间呢?因为 [ 0 , 100 ) [0,100) [0,100)中的数字位数未达到 3 位,而我们此时仅考虑 3 位情况)。随后开始考虑位数为 2 的所有数字,此时可以发现,所有位数为 2 的数字一定小于 y,那么答案中一定包含了所有位数为 2 的数字中满足要求的数字。

然而,按照上面的策略计算出来的结果为 23,而正确的结果是 25,因为我们漏算了大于 400 而小于 y 的数字(420、424),所以对于遍历的每一位数,当当前位数以前的所有数字(比如枚举到第二位,则当前数字为 4、2)是否满足相邻两位绝对差等于 2,若满足,则加上可以放在这里的数字的情况。

ll dp[20][10]; // i 位的数字且第 i 位数字为 j 的所有方案数
void init()
{for(int i=0;i<=9;i++) dp[1][i]=1;for(int i=2;i<=18;i++) {for(int j=0;j<=9;j++) {if(j-2>=0) dp[i][j]+=dp[i-1][j-2];if(j+2<=9) dp[i][j]+=dp[i-1][j+2];}}
}
ll solve(string num)
{if(num.length()==1) return 0;ll res=0;int _last=-1;bool con=true;for(int i=0;i<num.length()-1;i++) {int _now=num[i]-'0';if(i==0) {for(int j=1;j<_now;j++) {res+=dp[num.length()-i][j];}}if(i) {for(int j=1;j<=9;j++) {res+=dp[num.length()-i][j];}}// 首位是 _now 的情况if(i&&con) {for(int j=0;j<_now;j++) {if(abs(_last-j)==2) {res+=dp[num.length()-i][j];}}}if(i) con=con&&abs(_now-_last)==2;_last=_now;}if(con) {int _now=num.back()-'0';for(int j=0;j<=_now;j++) {if(abs(_last-j)==2) res++;}}return res;
}

I.哲学问题

由于:奇数+奇数=偶数、偶数+奇数=奇数,当给出数组和为奇数时,halo赢。当给出总和为偶数时,halo只要从数组中取出一个奇数,就会使得数组和变为奇数,halo赢。
所以当存在奇数时,halo必胜

void solve()
{int n;cin>>n;bool odd=false;while(n--) {ll x;cin>>x;odd=odd||x%2;}cout<<(odd?"halo":"parry")<<'\n';
}

L.kids 们的字符串游戏

用变量来表示当前相较于最初字串是否反转,若反转,则加在最后的字符应当加在头部,加在头部的应当加在最后。

#include <bits/stdc++.h>
using namespace std;
int main()
{ios::sync_with_stdio(false),cin.tie(0);int n,m;string line;cin>>n>>m>>line;stack<char> _front,_end;bool _reverse=false;while(m--) {int a,b;char op;cin>>a;if(a==1) _reverse=!_reverse;else {cin>>b>>op;if(_reverse) b=3-b;if(b==1) _front.push(op);else _end.push(op);}}if(_reverse) {swap(_front,_end);reverse(line.begin(),line.end());}while(!_front.empty()) {cout<<_front.top();_front.pop();}cout<<line;vector<char> End;while(!_end.empty()) {End.push_back(_end.top());_end.pop();}for(int i=End.size()-1;i>=0;i--) {cout<<End[i];}cout<<'\n';return 0;
}

这篇关于西安理工大学2024年程序设计校赛(校外同步赛)(ABCGIL)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同

查看MySql主从同步的偏移量方式

《查看MySql主从同步的偏移量方式》:本文主要介绍查看MySql主从同步的偏移量方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 1.mysql的主从同步方案mysqlphp为了在实现读写分离,主库写,从库读mysql的同步方案主要是通过从库读取主库的binl

MySQL主从同步延迟问题的全面解决方案

《MySQL主从同步延迟问题的全面解决方案》MySQL主从同步延迟是分布式数据库系统中的常见问题,会导致从库读取到过期数据,影响业务一致性,下面我将深入分析延迟原因并提供多层次的解决方案,需要的朋友可... 目录一、同步延迟原因深度分析1.1 主从复制原理回顾1.2 延迟产生的关键环节二、实时监控与诊断方案

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

Java中将异步调用转为同步的五种实现方法

《Java中将异步调用转为同步的五种实现方法》本文介绍了将异步调用转为同步阻塞模式的五种方法:wait/notify、ReentrantLock+Condition、Future、CountDownL... 目录异步与同步的核心区别方法一:使用wait/notify + synchronized代码示例关键

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二