Acwing——第二场热身赛

news2024/11/19 19:29:43

题目链接

AcWing 3547. 特殊数字
AcWing 3548. 双端队列
AcWing 3549. 最长非递减子序列

题目描述

3547.特殊数字

我们规定,对于一个整数 a,如果其各位数字相加之和能够被 4 整除,则称它是一个特殊数字。

现在,给定一个整数 n,请你计算并输出不小于 n 的最小特殊数字。

输入格式

一个整数 n。

输出格式

一个整数,表示不小于 n 的最小特殊数字。

数据范围

对于 30% 的数据, 1 ≤ n ≤ 100 1≤n≤100 1n100
对于 100% 的数据, 1 ≤ n ≤ 1000 1≤n≤1000 1n1000

输入样例:

42

输出样例:

44

  • 时间复杂度: O ( n ) O(n) O(n)

代码:

#include<iostream>
using namespace std;

//计算 x 的每一位数的和
int fun(int x){
    string s = to_string(x);
    int ans = 0;
    for(auto &c:s) ans += (c-'0');
    return ans;
}

int main(){
    //根据题意直接模拟即可
    int n;
    cin>>n;
    while(true){
        if(fun(n) % 4 == 0) break;
        n++;
    }
    cout<<n<<endl;
    return 0;
}

3548.双端队列

给定一个双端队列,初始时队列为空。

你要对其进行 q 次操作,每次操作可能是以下三种之一:

L x,从队列的左端插入整数 x。
R x,从队列的右端插入整数 x。
? x,请你计算为了使已经处于队列中的整数 x 位于队列的最左端或最右端,至少需要从最左端或最右端弹出多少个数字。
保证操作 3 一定合法( ? x 中的 x 一定已经处于队列之中)。

每个数字最多被插入到队列中 1 次(队列中一定不会存在重复数字)。

注意,操作 3 只是询问最少需要弹出多少数字,不是真的要弹出它们,队列中的数字始终不会减少。

输入格式

第一行包含整数 q。

接下来 q 行,每行包含一个操作信息,格式如题所述。

输出格式

对于每个操作 3,输出一行,一个整数表示结果。

数据范围

对于 30% 的数据, 1 ≤ q ≤ 30 , 1 ≤ x ≤ 30 1≤q≤30,1≤x≤30 1q30,1x30
对于 100% 的数据, 1 ≤ q ≤ 2 × 1 0 5 , 1 ≤ x ≤ 2 × 1 0 5 1≤q≤2×10^5,1≤x≤2×10^5 1q2×105,1x2×105
保证至少包含一个操作 3,
保证操作 1 和 2 不会重复插入数字。
保证操作 3 不会询问队列中不存在的数字。

输入样例1:

8
L 1
R 2
R 3
? 2
L 4
? 1
L 5
? 1

输出样例1:

1
1
2

输入样例2:

10
L 100
R 100000
R 123
L 101
? 123
L 10
R 115
? 100
R 110
? 115

输出样例2:

0
2
1

分析:
根据题意,我们只需要构建一个双向链表,可以在前面插入元素,也可以在后面插入元素。只需要遍历一遍链表找到对应的x的位置,要弹出左边元素的个数 与 要弹出右边元素的个数 取个min即可。

但实际上我们并不需要真正的模拟这个过程。我们只需要对相应的下标做操作即可。

在这里插入图片描述
在这里插入图片描述

  • 时间复杂度: O ( n ) O(n) O(n)

代码:

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

const int N = 2e5+10;
int idx[N];

int main(){
    int q;
    cin>>q;
    int l = 0,r = -1;
    
    while(q--){
        char op[2];
        int x;
        scanf("%s%d",op,&x);
        if(*op == 'L'){
            idx[x] = --l;
        }
        else if(*op == 'R'){
            idx[x] = ++r;
        }
        else{
            cout<<min(idx[x] - l,r - idx[x])<<endl;
        }
    }
    return 0;
}

3549. 最长非递减子序列

给定一个长度为 n 的数字序列 a 1 , a 2 , … , a n a_1,a_2,…,a_n a1,a2,,an,序列中只包含数字 1 和 2。

现在,你要选取一个区间 [ l , r ] ( 1 ≤ l ≤ r ≤ n ) [l,r](1≤l≤r≤n) [l,r](1lrn),将 a l , a l + 1 , … , a r a_l,a_{l+1},…,a_r al,al+1,,ar进行翻转,并且使得到的新数字序列 a 的最长非递减子序列的长度尽可能长。

请问,这个最大可能长度是多少?

一个非递减子序列是指一个索引为 p 1 , p 2 , … , p k p_1,p_2,…,p_k p1,p2,,pk 的序列,满足 p 1 < p 2 < … < p k p_1<p_2<…<p_k p1<p2<<pk 并且 a p 1 ≤ a p 2 ≤ … ≤ a p k a_{p1}≤a_{p2}≤…≤a_{pk} ap1ap2apk,其长度为 k。

输入格式

第一行一个整数 n。

第二行 n 个空格隔开的数字 1 或 2,表示 a 1 , … , a n a_1,…,a_n a1,,an

输出格式

输出一个整数,表示得到的新数字序列 a 的最长非递减子序列的最大可能长度。

数据范围

对于 30% 的数据, 1 ≤ n ≤ 100 1≤n≤100 1n100
对于 100% 的数据, 1 ≤ n ≤ 1 0 6 1≤n≤10^6 1n106
本题读入数据规模较大,需注意优化读入。
C++ 尽量使用 scanf 读入,Java 尽量使用 BufferedReader 读入。

输入样例1:

4
1 2 1 2

输出样例1:

4

输入样例2:

10
1 1 2 2 2 1 1 2 2 1

输出样例2:

9

分析:

按照题意,我们翻转一个区间 [ l , r ] [ l , r ] [l,r]之后,将会得到最大的非递减上升子序列。那么其翻转之前的形式应该是如下的:

在这里插入图片描述
所以可能有四种合法情况:

  • 只有第一段存在,111111…,用 s1 记录第一种情况的长度
  • 第一段和第二段都存在,111111122222…,用 s2 记录第二种情况的长度
  • 前三段都存在,11111222211111,用 s3 记录第三种情况的长度
  • 四段全部存在,11111222211112222,用 s4 记录第四种情况的长度
  • 最后的答案即为 max{ s1,s2,s3,s4 }
  • 时间复杂度: O ( n ) O(n) O(n)

代码:

#include<iostream>
using namespace std;

int main(){
    int n ;
    cin>>n;
    int s1 = 0,s2 = 0,s3 = 0,s4 = 0;
    for(int i = 1;i <= n;i++){
        int x;
        scanf("%d",&x);
        //如果x = 1,有可能是加在 s1 后面,也有可能是加在 s3 后面
        //s1   111111....
        //s3   11111222211111...
        if(x == 1){
            s1++;
            //s3 此时的情况有可能是   1111122222 + 1 
            //也有可能是  1111122221111...  + 1
            //所以要取两者的最大值
            s3 = max(s3+1,s2+1);
        }
        //x = 2既有可能是加在 s2 后面,也有可能是加在 s4 后面
        //s2 111112222....
        //s4 11111222211112222....
        else{
            s2 = max(s1+1,s2+1);
            s4 = max(s3+1,s4+1);
        }
    }
    cout<<max(s3,s4)<<endl;
    return 0;
}

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

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

相关文章

算法第十一期——BFS(广度优先搜索)入门与应用

目录 BFS BFS:找最短路路径 BFS:用队列实现 特点 最短路径问题用BFS 应用场合 例题一 【思路】 输出路径的两种方法 简单方法 标准方法&#xff08;栈&#xff09; BFS:连通性判断 例题二&#xff1a;全球变暖 【思路】 BFS的三种实现 1、queue实现 2、 li…

分享66个Java源码,总有一款适合您

Java源码 分享66个Java源码&#xff0c;总有一款适合您 下面是文件的名字&#xff0c;我放了一些图片&#xff0c;文章里不是所有的图主要是放不下...&#xff0c;大家下载后可以看到。 源码下载链接&#xff1a;https://pan.baidu.com/s/1wnPO7GfR_cVmDb2qx-4vEw?pwdlrsu …

Android 深入系统完全讲解(16)

2 属性权限 我们来看下属性权限的整体流程&#xff0c;简单分析下这个模块。init.cpp -->property_init() init 进程 进入第二阶段的时候&#xff0c;初始化属性。 关键点&#xff0c;创建了一个目录&#xff0c;这个目录就是我们属性后续会存在的地方。加载对应文件中的配…

[ADT笔记]图(graph)

定义 其实跟树差不多&#xff0c;但是树强调的是节点&#xff08;data&#xff09;&#xff0c;图则既强调节点又强调边。 分类 有向图&#xff08;边有方向&#xff09;无向图&#xff08;边没方向&#xff09; 例如&#xff0c;在无向图里<j,i>和<i,j>是同一…

(简单成功版本)Mysql配置my.ini文件

目录 一、背景 二、删除原有的mysql服务 三、初始化mysql 四、自行添加my.ini文件 五、新建mysql服务 六、启动mysql服务 七、设置数据库密码 7.1 登录mysql数据库 7.2 修改root用户密码 八、配置my.ini问题 一、背景 我在两台电脑上安装了MySQL Server 8.0&#xff0…

谈谈你对React的理解?

1、思路 讲讲概念、说用途、设计思路和原理、有什么优缺点 2、概念 一句话解释技术本质&#xff0c;React是javascript的UI库&#xff0c;通过组件化的方式解决视图层开发复用问题&#xff0c;本质是组件化框架。 viewfn(props) const A(props)><div>A</div&g…

java打包之jar和war为何出现又有什么区别

文章目录jar为什么诞生如何打jar包war为什么诞生如何打war包jar与war有什么区别jar与war的种类&#xff08;进阶&#xff09;参考资料jar为什么诞生 java工程有大量文件&#xff0c;在部署的时候需要向服务器上传大量文件&#xff0c;如果有了jar的话&#xff0c;只需上传一个…

鹅鹅鸭又崩了咋办?试试这5个方法

要说最近大火的游戏&#xff0c;鹅鹅鸭/鹅鸭杀绝对算一个。这种休闲策略游戏&#xff0c;还能跟朋友、家人约着一起玩。 不过最近很多玩家在玩鹅鹅鸭时都遇到闪退、卡顿、进不去等情况&#xff0c;虽然有太火爆服务器不稳定&#xff0c;服务器被攻击的原因&#xff0c;但有时候…

【机器学习之模型融合】Voting投票法基础理论

目录 1、认识模型融合&#x1f338; 2、模型融合和集成算法的区别&#x1f339; 3、常见模型融合方式&#x1f341; 4、投票法Voting&#x1f33f; 4.1、不同的投票方法&#x1f334; 1、认识模型融合&#x1f338; 在机器学习竞赛界&#xff0c;流传着一句话&#xff1a;…

redis基本数据结构使用与场景

string&#xff08;字符串&#xff09;用法使用场景list&#xff08;列表&#xff09;用法使用场景set&#xff08;不可重复&#xff0c;乱序的集合&#xff09;用法使用场景zset &#xff08;相对于set集合 增加了score属性&#xff0c;score可用于排序&#xff09;用法使用场…

持续集成:使用Jenkins API创建视图

持续集成&#xff1a;通过Jenkins API创建项目和节点介绍了使用jenkins API来创建项目和新建节点&#xff0c;jenkins API也可以创建视图&#xff08;view&#xff09;。 目录1. 获取视图配置文件2. 创建视图3. 将job添加到视图1. 获取视图配置文件 jenkins API创建视图&#…

Golang学习之路——之tinyrpc源码阅读

tinyrpc是一个高性能的基于protocol buffer的rpc框架。项目代码非常少&#xff0c;很适合初学者进行golang的学习。 如果你正在为没有资料学习发愁&#xff0c;文末有相关的学习资料获取方式 tinyrpc功能 tinyrpc基于TCP协议&#xff0c;支持各种压缩格式&#xff0c;基于pr…

Junit单元测试

Junit测试简介什么是单元测试单元测试是针对最小的功能单元编写测试代码Java程序最小的功能单元是方法单元测试就是针对单个Java方法的测试测试驱动开发(TDD)使用main()方法测试的缺点&#xff1a;只能有一个main()方法&#xff0c;不能把测试代码分离没有打印出测试结果和期望…

python+vue2+nodejs 搜索引擎课设 SCAU数信学院本科生通知检索(附源码)

前言 这个系统主要实现了以下功能&#xff1a; 爬虫&#xff1a;数据爬取及分词后端&#xff1a;数据库全文模糊搜索、高频词获取前端&#xff1a;输入拼音缩写或文字后匹配输入建议、搜索、列表分页、高亮关键词、相关度排序及时间排序、深色模式及浅色模式切换 爬虫&#x…

兔八哥与猎人

兔八哥与猎人 题目描述 兔八哥躲藏在树林旁边的果园里。果园有 MNM \times NMN 棵树&#xff0c;组成一个 MMM 行 NNN 列的矩阵&#xff0c;水平或垂直相邻的两棵树的距离为 111。兔八哥在一棵果树下。 猎人背着猎枪走进了果园&#xff0c;他爬上一棵果树&#xff0c;准备杀…

springboot整合JSR303校验

4.7 JSR303校验 4.7.1 统一校验的需求 前端请求后端接口传输参数&#xff0c;是在controller中校验还是在Service中校验&#xff1f; 答案是都需要校验&#xff0c;只是分工不同。 Contoller中校验请求参数的合法性&#xff0c;包括&#xff1a;必填项校验&#xff0c;数据…

Python_内置函数

1、abs()&#xff1a;绝对值 2、all()&#xff1a;接受一个可迭代对象&#xff0c;如果对象里的所有元素的bool运算值都是True&#xff0c;那么返回True,否则返回False 3、any()&#xff1a;接受一个可迭代对象&#xff0c;如果对象里有一个元素的bool运算值都是True&#xff0…

CSS实现从下至上弹出的抽屉动画

从下至上展开抽屉动画<!DOCTYPE html> <html><head><meta charset"UTF-8"><meta name"viewport" content"initial-scale1.0, maximum-scale1.0, user-scalableno" /><title></title><style>.co…

码农抓取商品详情API调用,Json和XML等格式

API 指的 是一些预定义的函数&#xff0c; 可以 提供给应用程序和开发人员基于软件或硬件访问一组例程的 功能 &#xff0c; 而 不再需要访问源代码或理解内部工作机制细节。 API 可以用于 于开发使用相同数据的其他应用程序&#xff0c;比如公司&#xff0c;他们可以创建一个A…

携手向前,欧拉沙龙双品牌联合运营纯电赛道再提速

面对波诡云谲的市场环境和竞争格局&#xff0c;企业只有不断变革&#xff0c;才能赢得更多的发展机遇&#xff0c;拥有属于自己的生存空间。 在2022年12月底广州国际车展和今年1月初的海口新能源车展上&#xff0c;欧拉携好猫、好猫GT、芭蕾猫、闪电猫&#xff0c;沙龙携高端车…