萌新联赛 2024第(六)场:郑州大学 8.21

2024-08-23 23:44

本文主要是介绍萌新联赛 2024第(六)场:郑州大学 8.21,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • [ 8.21 2024第(六)场:郑州大学 ](https://ac.nowcoder.com/acm/contest/89237#question)
    • C 16进制世界
      • 思路
      • 代码
    • G 等公交车
      • 思路
      • 代码
    • H 24点
      • 思路
      • 代码
    • B 百变吗喽
      • 思路
      • 代码
    • L koala的程序

8.21 2024第(六)场:郑州大学

C 16进制世界

若干月饼,有饱腹度和幸福值。要求饱腹度小于M,幸福值之和为16的倍数。

求,最多吃多少月饼。

背包都学完了,这题都没做出来,丢人

思路

这是01背包和二维费用背包问题的结合。

i i i表示dp的阶段

j j j 更新不同体积下最大数量

k k k 更新不同余数下最大数量

因为要求幸福值和为16的倍数,即余数为0.所以我们需要初始化为**-INF, f [ 0 ] [ 0 ] = 0 f[0][0]=0 f[0][0]=0**。

这样保证 f [ i ] [ 0 ] f[i][0] f[i][0] 表示的结果一定是余数为0,饱腹值为i。

不懂的话可以看这篇博客

背包九讲(灵魂版)-CSDN博客

代码

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
#define fir(i,a,b) for(int i=a;i<=b;i++)
const int N=1e5+10;
int v,w,f[N][20];
signed main()
{IOSmemset(f,128,sizeof(f));//初始化无穷小f[0][0]=0;int n,m;cin>>n>>m;fir(i,1,n){cin>>v>>w; w%=16;for(int j=m;j>=v;j--)for(int  k=0;k<=15;k++)//遍历余数,可正序,倒序,’二维费用背包‘{f[j][k]=max(f[j-v][(k+16-w)%16]+1,f[j][k]);}}  int ans=0;fir(i,0,m)//这种初始化,需要比较一下ans=max(ans,f[i][0]);cout<<ans<<'\n';
}

G 等公交车

给出递增发车时间,站点距离。判断需要等多长时间。

题目很简单,赛后发现暴力也能过。可惜没早点看,说到底还是二分不够熟悉,脑子不清晰,大于小于都没搞清,17:02,A也没用了

思路

由于递增,二分查找合适车辆。m+1初始化INF,这样赶不上,l=m+1

代码

const int N=1e5+10;
int a[N],b[N],t,x;
bool check(int mid)
{if(b[mid]+a[x]<t) return 1;return 0;
}
signed main()
{IOSint n,m;cin>>n>>m;fir(i,1,n)cin>>a[i];fir(i,1,m){ cin>>b[i];}  b[m+1]=2000000020;int q;cin>>q;while(q--){cin>>t>>x;int l=1,r=m+1;while(l<r){int mid=(l+r)>>1;if(check(mid)) l=mid+1;else r=mid;}if(l==m+1) cout<<"TNT\n";else cout<<b[l]+a[x]-t<<'\n';}
}

H 24点

给你1-13的四个数字,询问能否组成24.

你可是玩过24点的,怎么这个都没做出来呀,不就是±*/么,全排列函数没记住!考虑那么多括号干嘛,仔细想一想,已经全排列了,再把+ - * /交换一下,已经解决很多括号问题了,再考虑除法精度,ok。不过还是相信你的,给你时间,可以A

思路

运用全排列函数列举不同组合

对于加减乘除,利用函数运算

i , j , k i,j,k i,j,k 循环三个运算符号

if(A||B)

A 从前往后依次运算

B (a,b)(c,d) 前后加两个括号

减,除,交换项,分别考虑两次。

即**(a,b)考虑 a/b b/a**

目的是减少括号的列举

a/(b+c-d)

对于后三个加括号,可以这样排列

b c d a

运用A ,从前往后依次算

代码

#include <bits/stdc++.h>
using namespace std;double c(double x, double y, int op) {if (op == 0) return x + y;else if (op == 1) return x - y;else if (op == 2) return y - x;else if (op == 3) return x * y;else if (op == 4) return x / y;else if (op == 5) return y / x;return 0;
}void solve() {int a[4];for (int i = 0; i < 4; i++) {string s;cin >> s;if (s == "A") a[i] = 1;else if (s == "J") a[i] = 11;else if (s == "Q") a[i] = 12;else if (s == "K") a[i] = 13;else if (s == "10") a[i] = 10;else a[i] = s[0] - '0';}sort(a, a + 4);do {for (int i = 0; i < 6; i++)for (int j = 0; j < 6; j++)for (int k = 0; k < 6; k++) if (abs(c(c(c(a[0], a[1], i), a[2], j), a[3], k) - 24.0) < 1e-8 ||abs(c(c(a[0], a[1], i), c(a[2], a[3], j), k) - 24.0) < 1e-8)return cout << "YES\n", void();} while (next_permutation(a, a + 4));cout << "NO\n";
}int main() {ios::sync_with_stdio(false), cin.tie(nullptr);int T;cin >> T;while (T--) solve();
}

B 百变吗喽

给两个字符串,s,t.长度差一。

s中能不能插入一个字符变成t.

几种插法,分别插哪,插谁

思路

赛事代码太麻烦,整理大佬的.

双指针,分别从首尾查找,遇到不同字符停止。

如果能插一个字符相等,i1>=i2

虽然我的复杂,但是至少A的不算很慢,也没有烦人的bug

代码

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int n,i1,i2;
string s1,s2;
int main(){
cin>>s1>>s2;
n=s2.length();
for(i1=0;i1<n-1 && s1[i1]==s2[i1];i1++);
for(i2=n-1;i2>=0 && s1[i2-1]==s2[i2];i2--);
if(i2<=i1){
cout<<i1-i2+1<<endl;
for(int i=i2;i<=i1;i++)
cout<<i<<" "<<s2[i]<<endl;
}
else cout<<0<<endl;
return 0;
}

L koala的程序

约瑟夫问题

请看博客约瑟夫环问题(模板题,递推,树状数组,双端队列)-CSDN博客

这篇关于萌新联赛 2024第(六)场:郑州大学 8.21的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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. 福昕轻松