cf集合***

当周cf集合,我也不知道是不是当周的了,麻了,下下周争取写到e补f

C. Kevin and Puzzle(999)

题解:一眼动态规划,但是具体这个状态应该如何传递呢?

关键点:撒谎的人不相邻,

于是,就有以下两种情况

如果前一个不是liar,那么当前这个人和前一个人的a[i]都一定相同,满足a[i]==a[i-1],则可以状态转移

前一个人是liar,那么当前这个人和前一个的前一个人一定不是liar,满足a[i]==a[i-2]+1,则可以状态转移

代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod = 998244353;
int n,m;
vector<int>a;
void solve() {cin>>n;a.clear();int dp[n+10];memset(dp,0,sizeof dp);a.push_back(0);for(int i=0;i<n;i++) {int x;cin>>x;a.push_back(x);}dp[0]=1;for(int i=1;i<=n;i++) {if(a[i]==a[i-1]) dp[i]+=dp[i-1];if(a[i]==a[i-2]+1) dp[i]+=dp[i-2];dp[i]%=mod;}cout<<(dp[n]+dp[n-1])%mod<<endl;
}
signed main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t=1;cin>>t;while(t--) {solve();}return 0;
}

D. Kevin and Numbers(999)

题解:

突破点:a中(abs(x-y)<=1)可以合并 == b中所有数都可以拆成x/2+(x-x/2)

b中不需要拆分的元素就是与a共有的元素,其余数都需要拆分,且拆分的过程和结果一定,用优先队列对a,b从大到小拆分,每次拆b中最大且a中没有的元素可保证b的拆分是必要的

所以逆向思维很重要<_>

代码:


#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod = 998244353;
int n,m;
map<int,int>ma;
map<int,int>mb;
bool com() {for(auto it=ma.begin();it!=ma.end();it++) {if(mb.find(it->first)!=mb.end()) {int num=min(it->second,mb[it->first]);it->second-=num;mb[it->first]-=num;}}priority_queue<int,vector<int>,less<int> >p;priority_queue<int,vector<int>,less<int> >q;for(auto it=ma.begin();it!=ma.end();it++) {while(it->second!=0) {p.push(it->first);it->second--;}}for(auto it=mb.begin();it!=mb.end();it++) {while(it->second!=0) {q.push(it->first);it->second--;}}while(q.size()) {if(!q.size()||!p.size()||q.size()>p.size()) {break;}//cout<<q.top()<<" "<<p.top()<<endl;if(q.top()==p.top()) {q.pop();p.pop();}else if(q.top()>p.top()) {int temp=q.top();q.pop();q.push(temp/2);q.push(temp-temp/2);}else {return false;}}if(q.size()||p.size()) return false;return true;
}
void solve() {cin>>n>>m;ma.clear();mb.clear();for(int i=0;i<n;i++) {int x;cin>>x;ma[x]++;}for(int j=0;j<m;j++) {int x;cin>>x;mb[x]++;}if(com()) {cout<<"YES"<<endl;}else {cout<<"NO"<<endl;}
}
signed main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t=1;cin>>t;while(t--) {solve();}return 0;
}

E. Kevin and And(999)

 题解:贪心的思路,每一个数可以更新cnt<m次,我们可以通过二进制枚举算出进行k次操作的最大贡献,对于单个 i,操作的收益是单调减的,因此可以用堆维护这个操作过程。

其次,这个题reminded me of BD202401(简单版)

代码:


#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod = 998244353;
int n,m;
int k;
#define PII pair<int,int>
vector<int>a;
vector<int>b;
int c[1<<11];
int s[100010][12];
int num[100010];
void solve() {cin>>n>>m;cin>>k;a.clear();b.clear();//memset(num,0,sizeof(num));//memset(s,0,sizeof(s));for(int i=0;i<n;i++) {int x;cin>>x;a.push_back(x);}for(int i=0;i<m;i++) {int x;cin>>x;b.push_back(x);}for(int i=0;i<1<<m;i++) {//二进制枚举1-m次操作c[i]=(1<<30)-1;for(int j=0;j<m;j++) {if(i>>j&1) c[i]&=b[j];}}priority_queue<PII,vector<PII>,less<PII> > q;int ans=0;for(int i=0;i<n;i++) {//s[i][k]表示a[i]进行k次操作的最大贡献for(int j=0;j<=m;j++) {s[i][j]=0;}for(int j=0;j<1<<m;j++) {int k=__builtin_popcount(j);s[i][k]=max(s[i][k],a[i]-(a[i]&c[j]));}ans+=a[i];num[i]=0;}for(int i=0;i<n;i++) {q.push({s[i][1],i});}while(k--) {//每次操作保证是最大贡献int p=q.top().second;ans-=q.top().first;q.pop();++num[p];if(num[p]<m) {q.push({s[p][num[p]+1]-s[p][num[p]],p});}}cout<<ans<<endl;
}
signed main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t=1;cin>>t;while(t--) {solve();}return 0;
}

E. Divisor Paths(ECR85)

思路:不愧是2200的题,对于我来说,确实是有点难的,相关很多知识点,单独拎一个出来,我都要思考好久

这个题,按照常规思路先建图,再求最短路数量(废话),但是,我们发现无论是空间还是时间都不够我们建图,所以我们考虑直接找最短路

最新学的一种思维方式,先列重点

1.y/x必须为素数

2.每走一条边都是增加或者减少一个质因子,边权也就是增加或者减少的因子个数,于是我们可以推测出:x→y的最优路径一定是x→gcd(x,y)→y (相反我认为也可以走最小公倍数(错的),但是质因子就不一定在D里面了,cf评论区有相关的证明)

因为这样能保证减少或增加的质因子是其他所有方案减少或增加的质因子的子集,那么显然减少或增加的因数个数是最少的。

x→gcd(x,y)这个过程中因数个数是在减少的,所以删去质因子的顺序可随意排列

gcd(x,y)→y 这个过程中同上

所以我们可以先分解D的因子,然后将x/gcd(x,y)进行质因数分解,因为x,gcd(x,y)都是D的因子,所以可以直接用D的质因子试,我们只需要知道x/gcd(x,y)​质因数分解出的质因子个数cnt即可(在这里提醒一下,我们要求的是方案数,所以最短路是多少是不需要计算的)

最后将x→gcd(x,y)以及gcd(x,y)→x的路径数相乘即可

(实际上这个题补完,我都不知道要怎么去写我的题解,我也有点懵)

代码:


#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=2e5+10;
int n,m;
#define PII pair<int,int>
const int mod = 998244353;
int f[N];
int inv[N];
vector<int>p;
int qpow(int a,int b) {int res=1;while(b) {if(b&1) res=(res*a)%mod;a=(a*a)%mod;b>>=1;}return res;
}
void init(int n) {f[0]=1;for(int i = 1; i <= n; i++) {f[i]=f[i-1]*i%mod;}inv[n] = qpow(f[n], mod - 2);for (int i = n; i; --i) {inv[i - 1] =  inv[i] * i % mod;//阶乘的逆元}
}
int get(int x) {int z = 1,tot=0;for(int i=0;i<p.size();i++) {int cnt=0;while(x%p[i]==0) x/=p[i],cnt++;//这里是组合数学,很细节了,没想到就wa吧z=z*inv[cnt]%mod;tot+=cnt;}return z*f[tot]%mod;
}
void solve() {cin>>n;init(210);int tmp = n;for(int i=2; i* i <= n; i++ ) {if(tmp % i == 0) {p.push_back(i);}while(tmp % i == 0) tmp/=i;}if(tmp > 1) p.push_back(tmp);//巧妙求质因数集合cin >> m;while( m-- ) {int  x, y;cin >> x>> y;int g = gcd (x,y);cout << get(x / g) *get(y / g) % mod << "\n";}}
signed main() {int t=1;//cin >> t;while (t--) {solve();}return 0;
}

D. Game With Triangles(1000)

思路:用g(p,q)表示面积和吗,可得kmax

由于f(k)=max(g(x,k-x)) 

  • 2x+k−x=x+k≤n⟷x≤n−k;
  • x+2(k−x)=2k−x≤m⟷x≥2k−m;
  • x≥0;
  • k−x≥0⟷x≤k.
  • 所以x的范围:max(0,2k−m)≤x≤min(k,n−k)

用两个前缀和统计两个面积最大值,由于f(k)的函数是一个凸函数,所以用三分求出最大值区间

#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,m;
int k;
const int N=1e5+10;
#define PII pair<int,int>
vector<int>a;
vector<int>b;
int asum[N];
int bsum[N];
void solve() {cin>>n>>m;for(int i=0;i<n;i++) {int x;cin>>x;a.push_back(x);}for(int i=0;i<m;i++) {int x;cin>>x;b.push_back(x);}sort(a.begin(),a.end());sort(b.begin(),b.end());asum[0]=0;bsum[0]=0;for(int i=1;i<=n;i++)asum[i]=asum[i-1]+(a[n-i]-a[i-1]);for(int i=1;i<=m;i++)bsum[i]=bsum[i-1]+(b[m-i]-b[i-1]);vector<int >ans;for(int i=1;2*i-m<=n-i;i++){int L=max((int)0,2*i-m),R=min(i,n-i);if(L>R)break;auto f=[&](int ka){return asum[ka]+bsum[i-ka];};while(R-L>3){int mL=(L*2+R)/3,mR=(L+R*2)/3;if(f(mL)>f(mR))R=mR;else L=mL;}int mans=0;for(int i=L;i<=R;i++){mans=max(mans,f(i));}ans.push_back(mans);}int kmax=(int)size(ans)-1;cout<<kmax<<"\n";for(int i=1;i<=kmax;i++)cout<<ans[i]<<" \n"[i==kmax];
}
signed main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t=1;cin>>t;while(t--) {solve();}return 0;
}

E. Graph Composition(998)

题解:

1.并查集。我们用fu,gu表示点u在两个图所在的集合。首先如果(u,v)∈f,并且g(u)≠g(v),那么这条边一定要删,g(u)≠g(v),在f中添加这条边;然后在枚举g的集合,如果v∈g并且v∉f,添加这条边

从无向图转换成集合,能够直接联想到并查集(但是我没有想到)

2.dfs。

代码:

#include<bits/stdc++.h>
using namespace std;
#define PII pair<int,int>
int n,m,k;
const int N=2e5+10;
vector<PII>a;
vector<PII>b;
int f1[N];
int f2[N];
void solve() {cin>>n>>m>>k;a.clear();b.clear();for(int i=0;i<=n;i++) f1[i] = i,f2[i] = i;function<int(int)> find1 =[&](int x)->int {return  x == f1[x] ? x : f1[x] = find1(f1[x]);};function<int(int)> find2 =[&](int x)->int {return  x == f2[x] ? x : f2[x] = find2(f2[x]);};for(int i=0;i<m;i++) {int x,y;cin>>x>>y;a.push_back({x,y});}for(int i=0;i<k;i++) {int x,y;cin>>x>>y;f2[find2(x)]=find2(y);b.push_back({x,y});}int ans=0;for(auto [x,y]:a) {// cout<<find1(x)<<" "<<find2(y)<<endl;if(find2(x) != find2(y)) {ans++;}else {f1[find1(x)]=find1(y);}}map<int,vector<int>>mp;for(int i=1;i<=n;i++) {mp[find2(i)].push_back(i);}for(int i=1;i<=n;i++) {for(auto & x:mp[i]) {if(find1(x) != find1(i)) {ans++;f1[find1(x)]=find1(i);}}}cout << ans << endl;}
int main() {int _=1;cin>>_;while (_--) {solve();}return 0;
}

B. Find the Permutation(997)

题解:我是万万没想到哈,我居然这题能写不出来,真是一天比一天菜了

代码:

#include <bits/stdc++.h>using namespace std;void solve() {int n;cin >> n;vector<string> g(n);for(auto &i : g) {cin >> i;}vector<int> p(n);iota(p.begin(), p.end(), 0);sort(p.begin(), p.end(),[&](int x, int y) {if(g[x][y] == '1') return x < y;else return x > y;});for(auto i : p) cout << i + 1 << " "; cout << '\n';
}signed main() {ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);int ttt = 1;cin >> ttt;while(ttt--) {solve();}
}

C. Palindromic Subsequences(997)

题解:构造,赛时没想出来,蠢

代码:


#include<bits/stdc++.h>
using namespace std;
const int N=2e5+10;
int n,m;
#define PII pair<int,int>int main() {int t;cin >> t;while (t--) {cin >> n ;cout << 1<<" "<<1 <<" ";for(int i = 3;i <= n-1;i += 1) cout<< i <<" ";cout << 1 << endl;}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/68785.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大模型概述(方便不懂技术的人入门)

1 大模型的价值 LLM模型对人类的作用&#xff0c;就是一个百科全书级的助手。有多么地百科全书&#xff0c;则用参数的量来描述&#xff0c; 一般地&#xff0c;大模型的参数越多&#xff0c;则该模型越好。例如&#xff0c;GPT-3有1750亿个参数&#xff0c;GPT-4可能有超过1万…

Linux-CentOS的yum源

1、什么是yum yum是CentOS的软件仓库管理工具。 2、yum的仓库 2.1、yum的远程仓库源 2.1.1、国内仓库 国内较知名的网络源(aliyun源&#xff0c;163源&#xff0c;sohu源&#xff0c;知名大学开源镜像等) 阿里源:https://opsx.alibaba.com/mirror 网易源:http://mirrors.1…

简单易懂的倒排索引详解

文章目录 简单易懂的倒排索引详解一、引言 简单易懂的倒排索引详解二、倒排索引的基本结构三、倒排索引的构建过程四、使用示例1、Mapper函数2、Reducer函数 五、总结 简单易懂的倒排索引详解 一、引言 倒排索引是一种广泛应用于搜索引擎和大数据处理中的数据结构&#xff0c;…

Deepseek智能AI--国产之光

以下是以每个核心问题为独立章节的高质量技术博客整理&#xff0c;采用学术级论述框架并增强可视化呈现&#xff1a; 大型语言模型深度解密&#xff1a;从哲学思辨到系统工程 目录 当服务器关闭&#xff1a;AI的终极告解与技术隐喻情感计算&#xff1a;图灵测试未触及的认知深…

如何用ChatGPT批量生成seo原创文章?TXT格式文章能否批量生成!

如何用ChatGPT批量生成文章&#xff1f;这套自动化方案或许适合你 在内容创作领域&#xff0c;效率与质量的天平往往难以平衡——直到AI写作技术出现。近期观察到&#xff0c;越来越多的创作者开始借助ChatGPT等AI模型实现批量文章生成&#xff0c;但如何系统化地运用这项技术…

【回溯+剪枝】组合问题!

文章目录 77. 组合解题思路&#xff1a;回溯剪枝优化 77. 组合 77. 组合 ​ 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 ​ 你可以按 任何顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,…

04树 + 堆 + 优先队列 + 图(D1_树(D7_B+树(B+)))

目录 一、基本介绍 二、重要概念 非叶节点 叶节点 三、阶数 四、基本操作 等值查询(query) 范围查询(rangeQuery) 更新(update) 插入(insert) 删除(remove) 五、知识小结 一、基本介绍 B树是一种树数据结构&#xff0c;通常用于数据库和操作系统的文件系统中。 B树…

【力扣】283.移动零

AC截图 题目 思路 遍历nums数组&#xff0c;将0删除并计数&#xff0c;最后在nums数组尾部添加足量的零 有一个问题是&#xff0c;vector数组一旦erase某个元素&#xff0c;会导致迭代器失效。好在有解决办法&#xff0c;erase会返回下一个有效元素的新迭代器。 代码 class …

Games104——引擎工具链高级概念与应用

世界编辑器 其实是一个平台&#xff08;hub&#xff09;&#xff0c;集合了所有能够制作地形世界的逻辑 editor viewport&#xff1a;可以说是游戏引擎的特殊视角&#xff0c;会有部分editor only的代码&#xff08;不小心开放就会变成外挂入口&#xff09;Editable Object&…

【力扣:新动计划,编程入门 —— 题解 ③】

—— 25.1.26 231. 2 的幂 给你一个整数 n&#xff0c;请你判断该整数是否是 2 的幂次方。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 如果存在一个整数 x 使得 n 2x &#xff0c;则认为 n 是 2 的幂次方。 示例 1&#xff1a; 输入&#xff1a;…

10 Flink CDC

10 Flink CDC 1. CDC是什么2. CDC 的种类3. 传统CDC与Flink CDC对比4. Flink-CDC 案例5. Flink SQL 方式的案例 1. CDC是什么 CDC 是 Change Data Capture&#xff08;变更数据获取&#xff09;的简称。核心思想是&#xff0c;监测并捕获数据库的变动&#xff08;包括数据或数…

【PyTorch】6.张量运算函数:一键开启!PyTorch 张量函数的宝藏工厂

目录 1. 常见运算函数 个人主页&#xff1a;Icomi 专栏地址&#xff1a;PyTorch入门 在深度学习蓬勃发展的当下&#xff0c;PyTorch 是不可或缺的工具。它作为强大的深度学习框架&#xff0c;为构建和训练神经网络提供了高效且灵活的平台。神经网络作为人工智能的核心技术&…

Python-基于PyQt5,wordcloud,pillow,numpy,os,sys等的智能词云生成器

前言&#xff1a;日常生活中&#xff0c;我们有时后就会遇见这样的情形&#xff1a;我们需要将给定的数据进行可视化处理&#xff0c;同时保证呈现比较良好的量化效果。这时候我们可能就会用到词云图。词云图&#xff08;Word cloud&#xff09;又称文字云&#xff0c;是一种文…

DeepSeek-R1论文研读:通过强化学习激励LLM中的推理能力

DeepSeek在朋友圈&#xff0c;媒体&#xff0c;霸屏了好长时间&#xff0c;春节期间&#xff0c;研读一下论文算是时下的回应。论文原址&#xff1a;[2501.12948] DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning 摘要&#xff1a; 我们…

【深度分析】DeepSeek大模型技术解析:从架构到应用的全面探索

深度与创新&#xff1a;AI领域的革新者 DeepSeek&#xff0c;这个由幻方量化创立的人工智能公司推出的一系列AI模型&#xff0c;不仅在技术架构上展现出了前所未有的突破&#xff0c;更在应用领域中开启了无限可能的大门。从其混合专家架构&#xff08;MoE&#xff09;到多头潜…

万物皆有联系:驼鸟和布什

布什&#xff1f;一块布十块钱吗&#xff1f;不是&#xff0c;大家都知道&#xff0c;美国有两个总统&#xff0c;叫老布什和小布什&#xff0c;因为两个布什总统&#xff08;父子俩&#xff09;&#xff0c;大家就这么叫来着&#xff0c;目的是为了好区分。 布什总统的布什&a…

Leetcode:350

1&#xff0c;题目 2&#xff0c;思路 首先判断那个短为什么呢因为我们用短的数组去挨个点名长的数组主要用map装长的数组max判断map里面有几个min数组的元素&#xff0c;list保存交集最后用数组返回list的内容 3&#xff0c;代码 import java.util.*;public class Leetcode…

Spring Boot 热部署实现指南

在开发 Spring Bot 项目时&#xff0c;热部署功能能够显著提升开发效率&#xff0c;让开发者无需频繁重启服务器就能看到代码修改后的效果。下面为大家详细介绍一种实现 Spring Boot 热部署的方法&#xff0c;同时也欢迎大家补充其他实现形式。 步骤一、开启 IDEA 自动编译功能…

LogicFlow 一款流程图编辑框架

LogicFlow是什么 LogicFlow是一款流程图编辑框架&#xff0c;提供了一系列流程图交互、编辑所必需的功能和灵活的节点自定义、插件等拓展机制。LogicFlow支持前端自定义开发各种逻辑编排场景&#xff0c;如流程图、ER图、BPMN流程等。在工作审批流配置、机器人逻辑编排、无代码…

Git进阶之旅:tag 标签 IDEA 整合 Git

第一章&#xff1a;tag 标签远程管理 git 标签 tag 管理&#xff1a; 标签有两种&#xff1a; 轻量级标签(lightweight)带有附注标签(annotated) git tag 标签名&#xff1a;创建一个标签git tag 标签名 -m 附注内容 &#xff1a;创建一个附注标签git tag -d 标签名…