codeforces周赛div3#855记录

news2024/11/26 18:21:15

目录

总结

一,A. Is It a Cat?

二,B. Count the Number of Pairs

三,C1. Powering the Hero (easy version)

四,C2. Powering the Hero (hard version)


总结

真羡慕ACM校队的同学,能AC七八题,甚至ak

可能别人从div4一道题都做不对,到div3,AC 九题,只需要几个月的时间😲

那么从div3AK到div2AK他们又需要多久呢?也许是半年?

div2AK的实力,拿铜牌是否有希望呢,观望大佬成长

对于字符串,vector, queue的常用函数的使用还很生疏,所幸经过这次锻炼,下次应该可以AC同类型的题

因为不熟练,浪费了接近一半的时间在百度搜vector和queue的用法,以及字符串常用函数

知识点

1,字符串常用函数

头文件#include<cstring>

1,截取子串

s.substr(i)从下标i开始截取到结尾,s.substr(i, j)从下标i开始截取j个字符

2,替换子串

s.replace(i, j, s1)用s1替换s中从下标i开始的j个字符

3,查找子串

s.find(s1) 查找s1在s中第一次出现的下标

s.rfind(s1) 查找s1在s中最后一次出现的下标

4,删除子串

s.erase(i, j)删除从下标i开始的j个字符

关于s.find()补充

#include<iostream>
#include<cstring>
using namespace std;

int main()
{
    string s1 = "babajiaoni";
    string s2 = "bajiao";
    string s3 = "babb";

    if(s1.find(s3) == string::npos) //找不到子串
        cout<<"找不到子串"<<endl;
    if(s1.find(s2) != string::npos) //能找到子串
        cout<<"能找到子串";
    return 0;
}
找不到子串
能找到子串

2,queue

→ (2条消息) C++优先队列priority_queue详解_priority_queue头文件_是一只派大鑫的博客-CSDN博客

→ 

(5条消息) C++队列queue用法详解(超详细)_轻松学C语言的博客-CSDN博客

3,vector

→ (5条消息) c++ vector详解_~不羁的博客-CSDN博客

反思

只过了2题,第三题一开始尝试vector + priority_queue,但是写了70多行,非常混乱,写写改改,最后还是没过

今早补题,才发现想复杂了,臆想多了一个限制条件,但是样例并没有体现我这个思路的错误

后来拿第三题(easy version)AC的代码提交第四题(hard),发现第四题也直接过了

一,A. Is It a Cat?

Problem - A - Codeforces

标签:模拟,字符串

这个思路不是很清晰,写写改改才AC,代码非常臃肿

用了字符串函数中的s.find()和s.rfind(),头文件是#include<cstring>

关键是,现在codeforces不知道为什么禁止中文注释了,说我不符合utf-8标准。。。。

这里又浪费了10分钟。。

AC  代码

#include<iostream>
#include<cstring> //s.find(s1)
using namespace std;
int main()
{
    int t, n;
    string s;
    cin>>t;
    while(t--) {
        int flag = 1;
        cin>>n;
        cin>>s;
        for(int i = 0; i < n; ++i)
            if(s[i] == 'M' || s[i] == 'E' ||
            s[i] == 'O' || s[i] == 'W')
                s[i] += 32;
        if(s.find('w') == string::npos || s.find('o') == string::npos
        || s.find('e') == string::npos || s.find('m') == string::npos) {
            cout<<"NO"<<endl;
            continue;
        }
        else if(s.find('w') < s.find('o') || s.find('o') < s.find('e')
        || s.find('e') < s.find('m')) {
            cout<<"NO"<<endl;
            continue;
        }
        else if(s.rfind('m') + 1 != s.find('e') ||
                s.rfind('e') + 1 != s.find('o') ||
                s.rfind('o') + 1 != s.find('w')) {
                    cout<<"NO"<<endl;
                    continue;
                }
        for(int i = 1; i <= s.rfind('m'); ++i)
            if(s[i] != s[i - 1]) {
                flag = 0;
                cout<<"NO"<<endl;
                break;
            }
        for(int i = s.find('e') + 1; i <= s.rfind('e'); ++i)
            if(s[i] != s[i - 1]) {
                flag = 0;
                cout<<"NO"<<endl;
                break;
            }
        for(int i = s.find('o') + 1; i <= s.rfind('o'); ++i)
            if(s[i] != s[i - 1]) {
                flag = 0;
                cout<<"NO"<<endl;
                break;
            }
        for(int i = s.find('w') + 1; i < n; ++i)
            if(s[i] != s[i - 1]) {
                flag = 0;
                cout<<"NO"<<endl;
                break;
            }
        if(flag)
            cout<<"YES"<<endl;
    }
    return 0;
}

二,B. Count the Number of Pairs

Problem - B - Codeforces 

标签:贪心,字符串

 

 初始思路不是很清晰,写了50多行才AC

AC  代码

#include<iostream>
#include<cstring>
using namespace std;
int a[26], b[26];
int main()
{
    int t, n, k, ans;
    string s;
    cin>>t;
    while(t) {
        t--;
        memset(a, 0, sizeof(a));
        memset(b, 0, sizeof(b));
        ans = 0;
        cin>>n>>k;
        cin>>s;
        for(int i = 0; i < n; ++i) {
            if(s[i] >= 'a' && s[i] <= 'z')
                a[s[i] - 'a']++;
            if(s[i] >= 'A' && s[i] <= 'Z')
                b[s[i] - 'A']++;
        }
        for(int i = 0; i < 26; ++i) {
            if(a[i] >= b[i]) {
                ans += b[i];
                a[i] -= b[i];
                b[i] = 0;
            }
            else {
                ans += a[i];
                b[i] -= a[i];
                a[i] = 0;
            }
        }
        for(int i = 0; i < 26; ++i) {
            if(a[i] >= 2)
                while(k > 0 && a[i] >= 2) {
                    ans += 1;
                    k--;
                    a[i] -= 2;
                }
            else if(b[i] >= 2)
                while(k > 0 && b[i] >= 2) {
                    ans += 1;
                    k--;
                    b[i] -= 2;
                }
            if(k == 0) break;
        }
        cout<<ans<<endl;
    }
    return 0;
}

三,C1. Powering the Hero (easy version)

Problem - C1 - Codeforces

标签:数据结构,贪心 

 

 这题臆想多了一个限制条件,多做了很多无用功,最后还不符合题意

简单的queue使用,其他都不需要了

30行优先队列能搞定的,我一开始愣是结合vector写了70行 

AC  代码

#include<iostream>
#include<queue>
#include<cstdio> //scanf()
using namespace std;
int main()
{
    int t, n;
    scanf("%d", &t);
    while(t) {
        t--;
        scanf("%d", &n);
        long long ans = 0, m;
        priority_queue<int>q;
        for(int i  = 0; i < n; ++i) {
            scanf("%lld", &m);
            if(m != 0) {
                q.push(m);

            }
            if(m == 0)
                if(!q.empty()) {
                    ans += q.top();
                    q.pop();
                }
        }
        cout<<ans<<endl;
    }
    return 0;
}

四,C2. Powering the Hero (hard version)

标签:数据结构,贪心

同第三题,只是数据量不同,第三题AC  代码提交,也能过

AC  代码

同第3

#include<iostream>
#include<queue>
#include<cstdio> //scanf()
using namespace std;
int main()
{
    int t, n;
    scanf("%d", &t);
    while(t) {
        t--;
        scanf("%d", &n);
        long long ans = 0, m;
        priority_queue<int>q;
        for(int i  = 0; i < n; ++i) {
            scanf("%lld", &m);
            if(m != 0) {
                q.push(m);

            }
            if(m == 0)
                if(!q.empty()) {
                    ans += q.top();
                    q.pop();
                }
        }
        cout<<ans<<endl;
    }
    return 0;
}

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

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

相关文章

飞天云动,站在下一个商业时代的门口

ChatGPT的爆火让AIGC再度成为热词&#xff0c;随之而来的是对其商业化的畅想——不是ChatGPT自身如何盈利&#xff0c;而是它乃至整个AIGC能给现在的商业环境带来多大改变。 这不由得令人想起另一个同样旨在改变世界的概念&#xff0c;元宇宙。不同的是&#xff0c;元宇宙更侧…

Apache Flink 1.16 功能解读

摘要&#xff1a;本文整理自阿里云高级开发工程师 Apache Flink Committer、Flink 1.16 Release Manager 黄兴勃&#xff08;断尘&#xff09;&#xff0c;在 FFA 2022 核心技术专场的分享。本篇内容主要分为四个部分&#xff1a;综述持续领先的流处理更稳定易用高性能的批处理…

传输线的物理基础(一):地、信号和均匀传输线

我们每天都听到用到传输线&#xff0c;那么什么是传输线呢&#xff1f;一条同轴线缆是传输线&#xff0c;多层PCB板中带参考平面的PCB走线是传输线&#xff0c;我们可以理解为&#xff0c;传输线由任意两个具有长度的导体组成。接下来我们会看到&#xff0c;一条传输线用来将信…

想象力训练

一、课程目的1、了解想象力2、想象力训练二、静态想象法常用在单一图片上&#xff0c;比如一辆自行车要点1、形象鲜明 (大脑中生动的展现它的样子)2、放大:一点点放大它(后续的课程讲解经常用到放大这个方法)3、缩小:一点一点缩小它4、变多:一个变两个&#xff0c;两个变三个&a…

C++---数字三角形模型---传纸条(每日一道算法2023.2.26)

注意事项&#xff1a; 本题dp思路与 “线性dp–方格取数” 一致&#xff0c;下方思路仅证明为什么使用方格取数的思路是正确的。 题目&#xff1a; 小渊和小轩是好朋友也是同班同学&#xff0c;他们在一起总有谈不完的话题。 一次素质拓展活动中&#xff0c;班上同学安排坐成…

安卓开发调试使用 Charles抓包Https请求

1、Windows电脑安装证书Help->SSL Proxying -> Install Charles Root Certificate2、手机安装证书证书保存到电脑上.crt结尾的文件Help->SSL Proxying -> Save Charles Root Certificate2.复制到手机上 3.安装证书以红米手机为例打开手机设置-->密码与安全-->…

php宝塔搭建部署实战多模板cms管理系统源码

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 本期给大家带来一套php开发的多模板cms管理系统源码。感兴趣的朋友可以自行下载学习。 技术架构 PHP7.0 nginx mysql5.7 JS CSS HTMLcnetos7以上 宝塔面板 文字搭建教程 下载源码&#xff0c;宝塔添加一…

在软件开发中如何将看板方法与 Scrum 集合使用?

什么是看板和 Scrum 的混合模式&#xff1f;适合在哪些场景使用&#xff1f;有哪些成功的案例可参考&#xff1f;本文将围绕以上问题展开。敏捷实践是一个团队过程&#xff0c;选择适合团队的敏捷框架时并没有什么技巧&#xff0c;无论您是使用看板方法、Scrum 还是两者的组合&…

【C++】vector的模拟实现(SGI版本)

吃不了自律的苦&#xff0c;又接受不了平庸的罪。想让自己变好&#xff0c;但又想舒服些。 你啊你……要么就不要去想&#xff0c;想了又不去做&#xff0c;犹犹豫豫&#xff0c;徘徊不前&#xff0c;患得患失… 文章目录一、四种构造函数1.vector的框架和无参构造2.构造函数调…

为什么FPGA在深度学习领域有着得天独厚的优势?

01 FPGA在深度学习领域有哪些优势 FPGA&#xff08;Field-Programmable Gate Array&#xff09;是一种灵活的可编程硬件设备&#xff0c;它在深度学习应用领域中具有许多优势。 首先&#xff0c;FPGA具有非常高的并行性。在深度学习中&#xff0c;许多计算都可以并行化&…

Verilog实现组合逻辑电路

在verilog 中可以实现的数字电路主要分为两类----组合逻辑电路和时序逻辑电路。组合逻辑电路比较简单&#xff0c;仅由基本逻辑门组成---如与门、或门和非门等。当电路的输入发生变化时&#xff0c;输出几乎&#xff08;信号在电路中传递时会有一小段延迟&#xff09;立即就发生…

sqlserver数据库备份策略及实战测试

文章目录启动SQL SERVER 代理服务配置完整备份差异备份和事务日志备份备份还原测试测试云端备份最近研究sqlserver数据库备份&#xff0c;这里吧测试过程总结分享&#xff01;sqlserver日志备份主要分为三种 &#xff1a;全量备份、差异备份、事务日志备份。全量备份&#xff1…

大话数据结构-线性表

1 定义 线性表是零个或多个数据元素的有限序列。 2 抽象数据类型 ADT 线性表(List)Data&#xff1a;线性表的数据对象集合为{al,a2,a3,....an}&#xff0c;每个元素的类型均为DataType。其中&#xff0c;除第一个元素a1外&#xff0c;每一个元素有且只有一个直接前驱元素&…

锁屏面试题百日百刷-Hive篇(八)

锁屏面试题百日百刷&#xff0c;每个工作日坚持更新面试题。锁屏面试题app、小程序现已上线&#xff0c;官网地址&#xff1a;https://www.demosoftware.cn。已收录了每日更新的面试题的所有内容&#xff0c;还包含特色的解锁屏幕复习面试题、每日编程题目邮件推送等功能。让你…

gitblit 安装使用

1 安装服务端 简而言之&#xff1a;需要安装 java&#xff0c;gitblit&#xff0c; git 三个软件 Windows 10环境使用Gitblit搭建局域网Git服务器 前言 安装Java并配置环境安装gitblit并配置启动gitblit为windows服务使用gitblit创建repository并管理用户 1.1 安装Java并配…

[Java·算法·中等]LeetCode215. 数组中的第K个最大元素

每天一题&#xff0c;防止痴呆题目示例分析思路1题解1分析思路2题解2分析思路3题解3&#x1f449;️ 力扣原文 题目 给定整数数组 nums 和整数 k&#xff0c;请返回数组中第 k 个最大的元素。 请注意&#xff0c;你需要找的是数组排序后的第 k 个最大的元素&#xff0c;而不…

REFL: 联邦学习中智能的设备选择方法

原创 齐天宇 隐私计算研习社 收录于合集#联邦学习54个现有的FL方案使用随机的参与者选择来提高选择过程的公平性&#xff0c;但是这会导致资源的低效利用和较低的训练质量。本文系统地解决了FL中资源效率低效的问题&#xff0c;展示了智能参与者选择和合并来自落后参与者的更新…

React-高阶组件

认识高级组件 高阶函数的维基百科定义:至少满足以下条件之一 1、接受一个或多个函数作为输入; 2、输出一个函数; JavaScript中比较常见的 filter、map、reduce 都是高阶函数 那么说明是高阶组件呢? 高阶组件的英文是 Higher-Order Components&#xff0c;简称为 HOC;官方的…

2023年如何通过软考初级程序员?

初级的考试难度不大&#xff0c;稍微有点编程基础&#xff0c;认真备考应该没什么大问题。 先清楚大纲&#xff1a; 高效备考&#xff01;理清考点&#xff0c;针对性复习 科目一&#xff1a;综合知识 75道单项选择题&#xff0c;1题1分&#xff0c;时长150分钟&#xff1b;…

Qt 防止程序退出

文章目录摘要QWidgetQML方法 1方法 2关键字&#xff1a; Qt、 eventFilter、 Close、 键盘、 任务管理器摘要 今天要聊得内容还是怎么防止别人关闭我的程序&#xff0c;之前都是在win下面&#xff0c;一般都是用过钩子连捕获键盘事件&#xff0c;完了吧对应的事件忽略&#x…