news 2026/5/11 20:23:50

noi-2025年12月16号作业

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
noi-2025年12月16号作业

题目:B4407 [语言月赛 202509] 逃避讲题的最好方法是:

网址:https://www.luogu.com.cn/problem/B4407

思路:我们分别使用mx、mn数组记录每一道题的最大值分数和最小分数,同时使用一个e数组来保存每一道题的分数。首先特判,如果人数小于等于2的话,一定要上台,然后我们记录一下要改变的次数并贪心地修改分数,如果需要改变的次数大于c的话,那么就一定要上台。最后,我们判断一下改的是否合格。

知识点:set的使用,思维题

代码:

#include<bits/stdc++.h> #define ll long long #define pii pair<int,int> #define pss pair<string,string> #define fi first #define se second #define pb push_back #define eb emplace_back using namespace std; const int maxn=3e3+100; ll a[maxn][maxn]; int n,m,s; ll mx[maxn],mn[maxn]; set<int>e[maxn]; void solve() { cin>>n>>m>>s; for(int i=1;i<=m;i++) { mx[i]=-1; mn[i]=1e17; e[i].clear(); } for(int i=1;i<=n;i++) { for(int j=1;j<=m;j++) { cin>>a[i][j]; mx[j]=max(mx[j],a[i][j]); mn[j]=min(mn[j],a[i][j]); } } for(int j=1;j<=m;j++) { for(int i=1;i<=n;i++) { e[j].insert(a[i][j]); } } int c; cin>>c; if(n<=2) { cout<<"up"<<'\n'; return; } int need=0; for(int i=1;i<=m;i++) { if(a[s][i]!=mx[i]&&a[s][i]!=mn[i]) continue; if(e[i].size()==1) { cout<<"up"<<'\n'; return; } if(a[s][i]==mx[i]) { auto it=e[i].begin(); a[s][i]=(*it)+1; }else{ auto it=e[i].end(); it--; a[s][i]=(*it)-1; } need++; } for(int i=1;i<=m;i++) { mx[i]=-1; mn[i]=1e17; } if(need>c) { cout<<"up"<<'\n'; return; } for(int i=1;i<=n;i++) { for(int j=1;j<=m;j++) { mx[j]=max(mx[j],a[i][j]); mn[j]=min(mn[j],a[i][j]); } } for(int i=1;i<=m;i++) { if(a[s][i]==mx[i]||a[s][i]==mn[i]) { cout<<"up"<<'\n'; return; } } cout<<"down"<<'\n'; } int main(){ ios::sync_with_stdio(false); cin.tie(0);cout.tie(0); int _; cin>>_; while(_--) solve(); return 0; }

题目:P1029 [NOIP 2001 普及组] 最大公约数和最小公倍数问题

网址:https://www.luogu.com.cn/problem/P1029

思路:首先,如果y%x!=0的话,那么答案一定为0。接着我们分别对x和y进行质数分解,如果对于对一个质数,x和y的次数不相等的话,那么就有两种可能。

知识点:求质数,质数分解

代码:

#include<bits/stdc++.h> #define ll long long #define pii pair<int,int> #define pss pair<string,string> #define fi first #define se second #define pb push_back #define eb emplace_back using namespace std; const int maxn=2e5+100; ll a[maxn],cnt; int n,m; bool is_pri(ll x) { for(int i=2;i*i<=x;i++) { if(x%i==0) return false; } return true; } void solve() { ll x,y; cin>>x>>y; if(y%x!=0) { cout<<0; return; } for(int i=2;i<=100000;i++) { if(is_pri(i)) { a[++cnt]=i; } } ll ans=1; for(int i=1;i<=cnt;i++) { ll cnt1=0,cnt2=0; while(x%a[i]==0) { x/=a[i]; cnt1++; } while(y%a[i]==0) { cnt2++; y/=a[i]; } if(cnt1!=cnt2) { ans=ans*2; } } cout<<ans<<'\n'; } int main(){ ios::sync_with_stdio(false); cin.tie(0);cout.tie(0); int _=1; // cin>>_; while(_--) solve(); return 0; }

题目:P14566 【MX-S12-T1】取模

网址:https://www.luogu.com.cn/problem/P14566

思路:把p从非常大的值一路减小,会发现其实就是对a数组进行压缩。

知识点:思维题

代码:

#include<bits/stdc++.h> #define ll long long #define pii pair<int,int> #define pss pair<string,string> #define fi first #define se second #define pb push_back #define eb emplace_back using namespace std; const int maxn=2e5+100; ll a[maxn]; int n,m; void solve() { cin>>n; for(int i=1;i<=n;i++) { cin>>a[i]; } sort(a+1,a+1+n); if(a[n]==0) { cout<<0<<'\n'; return; } ll v1=a[n]-a[1]; for(int i=1;i<=n;i++) { a[i]=a[i]%a[n]; } sort(a+1,a+1+n); ll v2=a[n]-a[1]; cout<<max(v1,v2)<<'\n'; } int main(){ ios::sync_with_stdio(false); cin.tie(0);cout.tie(0); int _=1; cin>>_; while(_--) solve(); return 0; }

题目:P12817 [NERC 2021] Deletive Editing

网址:https://www.luogu.com.cn/problem/P12817

思路:我们先从s中找到t,然后再判断一下能否合法删除

知识点:思维题

代码:

#include<bits/stdc++.h> #define ll long long #define pii pair<int,int> #define pss pair<string,string> #define fi first #define se second #define pb push_back #define eb emplace_back using namespace std; const int maxn=2e5+100; ll a[maxn]; int n,m; string s,t; int vis[maxn]; void solve() { cin>>s>>t; if(s==t) { cout<<"YES"<<'\n'; return; } reverse(s.begin(),s.end()); reverse(t.begin(),t.end()); int last=-1; int len=s.length(); for(int i=0;i<len;i++) { vis[i]=0; } for(auto ch1:t) { bool ok=false; for(int i=last+1;i<len;i++) { if(s[i]==ch1) { ok=true; vis[i]=1; last=i; break; } } if(!ok) { cout<<"NO"<<'\n'; return; } } map<char,int>p; for(int i=0;i<len;i++) { if(vis[i]) { if(p[s[i]]) { cout<<"NO"<<'\n'; return; } }else{ p[s[i]]=1; } } cout<<"YES"<<'\n'; } int main(){ ios::sync_with_stdio(false); cin.tie(0);cout.tie(0); int _=1; cin>>_; while(_--) solve(); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 20:44:10

为什么工作10年都没遇过分布式锁?

引言&#xff1a;分布式锁的「薛定谔状态」在2025年某次技术峰会上&#xff0c;某互联网大厂架构师分享的监控截图引发热议&#xff1a;核心交易系统QPS峰值突破50万&#xff0c;但分布式锁调用次数为零。这印证了行业中的一个普遍现象——多数开发者终其职业生涯都未真正接触过…

作者头像 李华
网站建设 2026/5/10 22:52:22

冻品小程序开发选哪家?首选万象生鲜配送系统

在生鲜冻品小程序开发领域&#xff0c;选择适配冷链管理、库存精准、履约高效的系统是核心。万象生鲜系统凭借对冻品行业的深度适配、全链路温控与数字化管理能力&#xff0c;成为冻品商家开发小程序的优选方案&#xff0c;下面从行业痛点、系统优势、对比分析等方面详细解析。…

作者头像 李华
网站建设 2026/5/2 7:33:22

langchain agent动态变更系统prompt

一.背景 LangChain Agent 作为大语言模型&#xff08;LLM&#xff09;驱动的智能体核心&#xff0c;** 系统 Prompt&#xff08;提示词&#xff09;** 是其行为准则与决策逻辑的 “顶层设计”—— 它定义了 Agent 的角色定位&#xff08;如 “智能客服”“数据分析师”&#xf…

作者头像 李华
网站建设 2026/5/7 18:45:04

springboot+jspm电力监测报修服务平台_34gate3m

目录已开发项目效果实现截图开发技术介绍系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&…

作者头像 李华
网站建设 2026/5/9 14:40:10

基于PSO - BP的时间序列预测:一键出图的奇妙之旅

基于粒子群优化算法优化BP神经网络(PSO-BP)的时间序列预测 PSO-BP时间序列 一键出图&#xff0c;只需替换成自己数据集即可&#xff0c;有教程。在数据的海洋中&#xff0c;时间序列预测一直是众多领域关注的焦点。今天咱就唠唠基于粒子群优化算法&#xff08;PSO&#xff09;优…

作者头像 李华
网站建设 2026/5/10 23:12:43

LAMMPS-VMD耦合:基于tcl语言反应力场分析化学键生成的成键数目研究工具

LAMMPS反应力场分子动力学模拟成键分析程序 基于vmd的tcl语言脚本支持反应力场原子成键数目分析。 主要用于统计化学反应涉及化学键生成和断裂的体系&#xff0c;比如煤燃烧&#xff0c;石墨烯合成过程等等。 用法简单&#xff0c;指定待计算的元素对即可得到对应键数目随模拟时…

作者头像 李华