coderforces round 894(div.3)

news2025/1/22 17:06:01

Problem - A - Codeforces

AC代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<set>
#include<vector>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=25;
char s[N][N];
int n,m;
void solve() {
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cin>>s[i][j];
        }
    }
    int cnt=0;
    string temp="vika";
    for(int j=1;j<=m;j++){
        for(int i=1;i<=n;i++){
            if(s[i][j]==temp[cnt]){
                cnt++;
                break;
            }
        }
    }
    if(cnt==4) cout<<"Yes"<<endl;
    else cout<<"No"<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

Problem - B - Codeforces

AC代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<set>
#include<vector>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=2e5+10;
int b[N];
int n;
void solve() {
    cin>>n;
    vector<int>ans;
    for(int i=1; i<=n; i++) cin>>b[i];
    ans.push_back(b[1]);
    for(int i=2; i<=n; i++) {
        int x=b[i-1];
        if(b[i-1]<=b[i]&&b[i]<=b[i+1]) ans.push_back(b[i]);
        else {
            x--;
            while(x>b[i]) x--;
            if(x>0) ans.push_back(x);
            ans.push_back(b[i]);
        }
    }
    cout<<ans.size()<<endl;
    for(auto v:ans) cout<<v<<' ';
    cout<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

Problem - C - Codeforces

一开始都是一列一列竖着放置的,后将其横着放置(长的放在下面),问形状是否和之前一样

如果可行的话,变换后形状是不变的,那么一列一列看,变换后的第一列高度和之前一样,假设高度为a[1],那么至少得有a[1]列高度大于等于1才能拼成第一列,同理至少得有a[2]列高度大于等于2才能拼成第二列...

可以用树状数组来记录有几列高度是小于等于x的,即为sum(x),然后mp[x]记录有几列高度等于x,n-(sum(x)-mp[x])即为有几列高度大于等于x

AC代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<map>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=2e5+10;
int a[N];
int tr[N];
int n;
//树状数组
int lowbit(int x) {
    return x & -x;
}
void add(int x,int c) {
    for(int i=x; i<=n; i+=lowbit(i)) tr[i]+=c;
}
int sum(int x) {
    int res=0;
    for(int i=x; i; i-=lowbit(i)) res+=tr[i];
    return res;
}
void solve() {
    cin>>n;
    map<int,int>mp;
    memset(tr,0,sizeof tr);
    for(int i=1; i<=n; i++) {
        cin>>a[i];
        mp[a[i]]++;//统计a[i]的个数
        add(a[i],1);
    }
    bool flag=true;
    for(int i=1; i<=n; i++) {
        if(n-(sum(i)-mp[i])<a[i]) {
            cout<<"No"<<endl;
            return;
        }
    }
    cout<<"Yes"<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

E.Kolya and Movie Theatre

一开始以为是dp,选与不选,然后选m个,但是状态转移不太好写

实际上这题是贪心

首先,假如我们选第一个,第三个,第五个,那么总共的娱乐值为a1+a3+a5-1*d-2*d-2*d=a1+a3+a5-5*d,所以我们将选的娱乐值全部加起来,然后看下标最大的是哪一个,记为i,再减去d*i即可

于是,我们可以贪心,将选择的放在优先队列中(肯定得放大于0的),然后当队列中的个数小于m时,就继续放,当队列中的个数等于m时,由于最大的下标一定,即减去的d*i一定,所以我们要使得放入队列的娱乐值这和最大,那么就要将队头(娱乐值最小的)和即将放入的比较,删去娱乐值最小的

AC代码: 

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#include<queue>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=2e5+10;
int a[N];
int n,m;
ll d;
void solve() {
    cin>>n>>m>>d;
    for(int i=1; i<=n; i++) cin>>a[i];
    priority_queue<int,vector<int>,greater<int>>q;
    ll sum=0;
    ll ans=0;
    for(int i=1; i<=n; i++) {
        if(a[i]<0) continue;
        if(q.size()==m&&q.top()<a[i]) {
            sum-=q.top();
            q.pop();
        }
        if(q.size()<m) {
            q.push(a[i]);
            sum+=a[i];
        }
        ans=max(ans,sum-d*i);
    }
    cout<<ans<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

Problem - D - Codeforces

组合数

首先,对于不同种的球,假设有x种球,那么组合数就是C(x,2),但是注意题目的要求是exactly,也就是说刚好n种

先二分找到第一个满足C(l,2)大于等于n的l,先特判如果C(l,2)刚好等于n,那么直接输出l

否则我们只能取l-1个不同种类的球,组合数就是C(l-1,2),然后补足剩下的,假设还差diff个,那么就在原来已经有的球中选diff种,每种球加一个,那么答案即为l-1+diff

可以保证,diff一定小于等于l-1,因为C(l-1,2)小于n,C(l,2)大于等于n,diff等于n-C(l-1,2),所以diff小于等于C(l,2-C(l-1,2),即l-1

AC代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<stack>
#define endl '\n'
#define int long long
using namespace std;
typedef long long ll;
int n;
void solve() {
    cin>>n;
    int l=0,r=2e9;
    while(l<r){
        int mid=(l+r)/2;
        if(mid*(mid-1)/2>=n) r=mid;
        else l=mid+1;
    }
    if(l*(l-1)/2==n){
        cout<<l<<endl;
        return;
    }
    int diff=n-(l-1)*(l-2)/2;
    int res=l-1+diff;
    cout<<res<<endl;
}
signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0); 
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

Problem - F - Codeforces

原本是想用贪心的,优先杀死能量值大的怪兽,于是写下了以下代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#define endl '\n'
#define int long long
using namespace std;
typedef long long ll;
int w,f;
int n;
void solve() {
    cin>>w>>f;
    cin>>n;
    priority_queue<int>q;
    for(int i=1; i<=n; i++) {
        int x;
        cin>>x;
        q.push(x);
    }
    //标记一下哪个增长的快
    int flag;
    if(w>f) flag=1;//sum1增长的快
    else flag=2;//sum2增长的快
    int cnt=0;//记录次数
    int sum1=0,sum2=0;


    while(q.size()) {
        sum1+=w,sum2+=f,cnt++;
        if(flag==1) {
            while(q.size()&&sum1>=q.top()) {
                sum1-=q.top();
                q.pop();
            }
            while(q.size()&&sum2>=q.top()) {
                sum2-=q.top();
                q.pop();
            }
        } else if(flag==2) {
            while(q.size()&&sum2>=q.top()) {
                sum2-=q.top();
                q.pop();
            }
            while(q.size()&&sum1>=q.top()) {
                sum1-=q.top();
                q.pop();
            }
        }
    }
    cout<<cnt<<endl;
}
signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

但是从第一个样例可以看成,似乎贪心并不可行,优先杀死大的并不能得到正确答案

解析:

怪兽的生命值的总和是一定的,我们选择一部分用水杀死,一部分用火杀死

然后具体哪些用水杀死,我们枚举所有的组合,相当于背包问题,选择哪些成为一个组合

假设生命值和为x用水杀死,生命值和为y用火杀死

那么次数即为max(x/w+(x%w!=0),y/f+(y%f!=0)),然后每次取min即可

法一:

枚举所有的组合可以用bitset,可以组合出的血量标记为1

首先,b[0]初始化为1,然后对于一个怪兽的生命值a,b|=b

由此,假设第一个怪兽的生命值为2,第二个怪兽的生命值为5,第三个怪兽的生命值为6,那么第0,2,5,6以及2+5,2+6,5+6位都标记为1

AC代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<bitset>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=1e6+10;
int a[N];
int w,f;
int n;
void solve() {
    cin>>w>>f;
    cin>>n;
    bitset<N>bt;
    int sum=0;
    for(int i=1;i<=n;i++){
        cin>>a[i];
        sum+=a[i];
    }
    bt[0]=1;
    for(int i=1;i<=n;i++) bt|=bt<<a[i];
    int ans=2e9;
    for(int i=0;i<=sum;i++){
        if(!bt[i]) continue;
        int x=i/w+(i%w!=0);
        int y=(sum-i)/f+((sum-i)%f!=0);
        ans=min(ans,max(x,y));
    }
    cout<<ans<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

法二:

背包

dp[i][j]表示从前i个怪兽里选,总的生命值为j是否可行

for(int i=1;i<=n;i++){
    for(int j=a[i];j<=sum;j++){
        dp[i][j]|=dp[i-1][j-a[i]];
    }
}

 

然后由于dp[100][1e6]会爆空间,所以优化成一维 

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#define endl '\n'
//#define int long long
using namespace std;
typedef long long ll;
const int N=1e6+10;
int a[N];
int dp[N];
int w,f;
int n;
void solve() {
    cin>>w>>f;
    cin>>n;
    int sum=0;
    for(int i=1;i<=n;i++){
        cin>>a[i];
        sum+=a[i];
    }
    memset(dp,0,sizeof dp);
    dp[0]=1;
    for(int i=1;i<=n;i++){
        for(int j=sum;j>=a[i];j--){
            dp[j]|=dp[j-a[i]];
        }
    }
    int ans=2e9;
    for(int i=0;i<=sum;i++){
        if(!dp[i]) continue;
        int x=i/w+(i%w!=0);
        int y=(sum-i)/f+((sum-i)%f!=0);
        ans=min(ans,max(x,y));
    }
    cout<<ans<<endl;
}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t=1;
    cin>>t;
    while(t--) {
        solve();
    }
    return 0;
}

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

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

相关文章

LeetCode——贪心篇(三)

目录 452. 用最少数量的箭引爆气球 435. 无重叠区间 763. 划分字母区间 56. 合并区间 738. 单调递增的数字 968. 监控二叉树 刷题顺序及思路来源于代码随想录&#xff0c;网站地址&#xff1a;https://programmercarl.com 452. 用最少数量的箭引爆气球 有一些球形气球贴…

系统架构设计专业技能 ·结构化需求分析 - 数据流图

现在的一切都是为将来的梦想编织翅膀&#xff0c;让梦想在现实中展翅高飞。 Now everything is for the future of dream weaving wings, let the dream fly in reality. 点击进入系列文章目录 系统架构设计高级技能 结构化需求分析 - 数据流图 一、数据流图的基本概念二、需…

操作系统——复习笔记

主要是按照王道考研408的ppt进行复习。 概述 操作系统概览 操作系统&#xff08;Operating System&#xff0c; OS&#xff09;是指控制和管理整个计算机系统的硬件和软件资源&#xff0c;并合理地组织调度计算机的工作和资源的分配&#xff1b;以提供给用户和其他软件方便的…

新装Ubuntu系统的一些配置

背景&#xff1a; 最近办公要在Ubuntu系统上进行&#xff0c;于是自己安装了一个Ubuntu22.04系统&#xff0c;记录下新系统做的一些基本配置。 环境 &#xff1a; 系统&#xff1a;Ubuntu-22.04内核&#xff1a;6.2.0-26-generic架构&#xff1a;x86_64 一、 配置root密码 新…

Brief. Bioinformatics2021 | sAMP-PFPDeep+:利用三种不同的序列编码和深度神经网络预测短抗菌肽

文章标题&#xff1a;sAMP-PFPDeep: Improving accuracy of short antimicrobial peptides prediction using three different sequence encodings and deep neural networks 代码&#xff1a;https://github.com/WaqarHusain/sAMP-PFPDeep 一、问题 短抗菌肽(sAMPs)&#x…

明牌空投 — 融资1200万美元的 AlienSwap 交互教程

本文仅为资讯分享&#xff0c;不构成任何投资建议&#xff0c;也不推荐您购买、出售或者持有任何加密货币。请读者朋友们 DYOR&#xff0c;理性看待区块链&#xff0c;提高风险意识&#xff0c;谨慎投资&#xff01; ★ 关于 AlienSwap AlienSwap 是一个基于社区的多链 NFT 聚…

基于Sentinel的微服务保护

前言 Sentinel是Alibaba开源的一款微服务流控组件&#xff0c;用于解决分布式应用场景下服务的稳定性问题。Sentinel具有丰富的应用场景&#xff0c;它基于流量提供一系列的服务保护措施&#xff0c;例如多线程秒杀情况下的系统承载&#xff0c;并发访问下的流量控制&#xff…

MySQL用户密码重设,保姆式教程!

✍前言 我MySQL的root用户密码给忘了&#xff0c;怎么办&#xff1f;MySQL用户如何修改密码&#xff1f;如果你被这类问题所困扰&#xff0c;那么本文将会为你排忧解难&#xff01;(本文基于Windows10和mysql Ver 8.0.33 for Win64 on x86_64版本而创作) 操作步骤 1️⃣First s…

LeetCode刷题笔记【32】:动态规划专题-4(二维背包问题、一维背包问题、分割等和子集)

文章目录 动态规划前置知识背包问题前置知识什么是背包问题, 背包问题举例背包问题的大致分类01背包完全背包 背包问题的通用解法 二维背包问题题目描述解题思路1 构建dp数组2 初始化dp数组3 遍历更新dp数组 代码 一维背包问题题目描述解题思路代码 416. 分割等和子集题目描述解…

Linux设备树详细学习笔记

参考文献 参考视频 开发板及程序 原子mini 设备树官方文档 设备树的基本概念 DT:Device Tree //设备树 FDT: Flattened Device Tree //开放设备树&#xff0c;起源于OpenFirmware (所以后续会见到很多OF开头函数) dts: device tree source的缩写 //设备树源码 dtsi: device …

Vuex核心 - 模块 module(进阶)创建拆分

文章目录 module分模块一、什么是 模块module二、module的好处三、模块创建-拆分 module分模块 一、什么是 模块module 在Vuex中&#xff0c;模块&#xff08;module&#xff09;是用来组织和管理状态&#xff08;state&#xff09;、行为&#xff08;actions&#xff09;、变…

CIO40--数字化转型之回报效益ROI(含表格)

一﹑对BOSS的好处 随时可以由系统中的资料掌握公司的营运状况。建立公司的管理体系及运作规范﹐由系统管理公司运作。建立公司营运的数据库﹐累积公司的管理经验知识﹐不会因人员异动而流失。由系统信息的整合﹐可以提升公司的反应速度﹐不需由人力统计﹐可减少错误﹐节省人力…

3D视觉测量:形位公差 GDT同轴度(附源码)

文章目录 0. 测试效果1. 基本内容2. 公共轴线法3. 实现代码(待添加)目标:通过3D视觉的方法测量圆柱的同轴度 0. 测试效果 1. 基本内容 "同轴度" 是一个工程学和制造业中常用的术语,用来描述一个对象、零件或装置的各个组成部分是否在一个共同的轴线上对齐…

自动驾驶之高精地图介绍

高精地图 文章目录 高精地图前言一、什么是高精地图 前言 一、什么是高精地图 高精地图(High Definitation Map,HD MAP)&#xff0c;和普通导航电子地图的主要区别是精度更高、信息更丰富。精度更高主要体现在高精地图的绝对坐标精度更高(指的是地图上某个目标和外部的真实世…

linux 网络接口的子接口的配置

参考&#xff1a; https://blog.csdn.net/baidu_38803985/article/details/104653205 在 Linux 中&#xff0c;网络接口通常以ethX的形式命名&#xff0c;其中X代表接口的编号&#xff0c;例如eth0代表第一个网络接口&#xff0c;eth1代表第二个&#xff0c;依此类推。虚拟子接…

嵌入式学习笔记(22)汇编实现时钟设置代码详解

4.6.1时钟设置的步骤分析 第1步&#xff1a;先选择不使用PLL。让外部24MHz原始时钟直接过去&#xff0c;绕过APLL那条路。 第2步&#xff1a;设置锁定时间&#xff08;PLL_LOCK&#xff09;。默认值是0x0FFF&#xff0c;保险起见我们设置0xFFFF 第3步&#xff1a;设置分频系…

Linux 服务器连接方式

这里服务器使用 Ubuntu 20.04.6 LTS aarch64&#xff0c;这篇文章就不说使用工具连接了&#xff0c;工具直接添加就好了&#xff0c;这里说下终端命令操作 SSH 命令使用密码连接 使用以下命令在终端进行密码连接 ssh usernamehostname如果是第一次连接 SSH 客户端会提示你是否…

盘点一个os.path.join()函数遇到的小问题(文末赠书)

点击上方“Python爬虫与数据挖掘”&#xff0c;进行关注 回复“书籍”即可获赠Python从入门到进阶共10本电子书 今 日 鸡 汤 连峰去天不盈尺&#xff0c;枯松倒挂倚绝壁。 大家好&#xff0c;我是皮皮。 一、前言 前几天在Python最强王者群【小马哥】问了一个os路径拼接处理的问…

Kafka入门,这一篇就够了(安装,topic,生产者,消费者)

目录 Kafka的安装文件与配置目录binconfig 配置文件server.propertiesproducer.propertiesconsumer.properties 命令行简单使用kafka-topics.sh新增查看列表查看详情修改删除 kafka-console-producer.shkafka-console-consumer.sh 概念集群代理broker主题topic分区partition偏移…

用递归实现字符串逆序(不使用库函数)

文章目录 前言一、题目要求二、解题步骤1.大概框架2.如何反向排列&#xff1f;3.模拟实现strlen4.实现反向排列5.递归实现反向排列 总结 前言 嗨&#xff0c;亲爱的读者们&#xff01;我是艾老虎尤&#xff0c;今天&#xff0c;我们将探索一个题目&#xff0c;这个题目对新手非…