news 2026/4/15 5:59:38

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/13 19:21:16

架构设计:ElasticSearch+HBase 海量存储架构设计与实现

一&#xff1a;百亿级 海量存储数据服务的业务背景 很多公司的业务数据规模庞大&#xff0c;在百亿级以上&#xff0c; 而且通过多年的业务积累和业务迭代&#xff0c;各个业务线错综复杂&#xff0c;接口调用杂乱无章&#xff0c;如同密密麻麻的蛛网&#xff0c;形成了难以理清…

作者头像 李华
网站建设 2026/4/11 21:43:07

centos7 磁盘I/O性能

磁盘I/O性能&#xff08;核心指标&#xff09;​需安装 sysstat工具包&#xff08;含 iostat、sar等&#xff09;&#xff0c;若未安装先执行&#xff1a;yum install -y sysstat # CentOS/RHEL&#xff08;1&#xff09;iostat -x 1&#xff1a;实时监控磁盘I/O&#xff08;推…

作者头像 李华
网站建设 2026/4/9 18:41:19

springboot+jspm海关通关辅助管理系统_aw930v86

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

作者头像 李华