Acwing——第二场热身赛
创始人
2024-05-11 18:42:02
0

题目链接

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

题目描述

3547.特殊数字

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

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

输入格式

一个整数 n。

输出格式

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

数据范围

对于 30% 的数据,1≤n≤1001≤n≤1001≤n≤100。
对于 100% 的数据,1≤n≤10001≤n≤10001≤n≤1000。

输入样例:

42

输出样例:

44

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

代码:

#include
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<

3548.双端队列

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

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

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

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

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

输入格式

第一行包含整数 q。

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

输出格式

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

数据范围

对于 30% 的数据,1≤q≤30,1≤x≤301≤q≤30,1≤x≤301≤q≤30,1≤x≤30。
对于 100% 的数据,1≤q≤2×105,1≤x≤2×1051≤q≤2×10^5,1≤x≤2×10^51≤q≤2×105,1≤x≤2×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
#include
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<

3549. 最长非递减子序列

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

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

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

一个非递减子序列是指一个索引为 p1,p2,…,pkp_1,p_2,…,p_kp1​,p2​,…,pk​ 的序列,满足 p1

输入格式

第一行一个整数 n。

第二行 n 个空格隔开的数字 1 或 2,表示 a1,…,ana_1,…,a_na1​,…,an​。

输出格式

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

数据范围

对于 30% 的数据,1≤n≤1001≤n≤1001≤n≤100。
对于 100% 的数据,1≤n≤1061≤n≤10^61≤n≤106。
本题读入数据规模较大,需注意优化读入。
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
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<

相关内容

热门资讯

findx耍原生安卓系统,深度... 亲爱的读者们,你是否厌倦了那些花里胡哨的定制系统,渴望回到那个纯净的安卓世界?今天,我要带你一起探索...
一加系统属于安卓系统吗,引领智... 你有没有想过,手机里的那个神奇的“一加系统”到底是不是安卓系统的一员呢?这可是个让人好奇不已的问题哦...
小米2刷安卓系统吗,探索安卓系... 亲爱的读者,你是否曾经对小米2这款手机刷安卓系统的事情感到好奇呢?今天,就让我带你一探究竟,揭开小米...
安卓7.0系统线刷包,深度解析... 你有没有发现,你的安卓手机最近有点儿“蔫儿”了?别急,别急,今天就来给你揭秘如何让你的安卓手机重焕生...
白菜系统和安卓拍照,开启智能生... 你知道吗?最近我在用手机拍照的时候,发现了一个超级酷的功能,简直让我爱不释手!那就是——白菜系统和安...
安卓系统查杀病毒,全方位守护您... 手机里的安卓系统是不是有时候会突然弹出一个查杀病毒的提示?别慌,这可不是什么大问题,今天就来给你详细...
iso系统与安卓各系统哪个好,... 你有没有想过,手机操作系统就像是我们生活中的不同交通工具,各有各的特色和优势。今天,咱们就来聊聊这个...
中柏怎么换安卓系统,解锁更多可... 你有没有发现,中柏的安卓系统有时候用起来还挺不顺手的?别急,今天就来手把手教你如何给中柏手机升级安卓...
安卓热点绕过系统验证,揭秘操作... 你是不是也遇到过这种情况?手机里的安卓热点突然不灵光了,系统验证总是跳出来,让人头疼不已。别急,今天...
安卓系统怎么关闭小艺,安卓系统... 亲爱的安卓用户们,你是否也和我一样,对手机里的小艺助手有些爱恨交加呢?有时候,它贴心得让人感动,有时...
安卓系统计划软件推荐,精选计划... 你有没有发现,手机里的安卓系统越来越智能了?这不,最近我可是挖到了一些超棒的安卓计划软件,它们不仅能...
收钱吧安卓系统插件,便捷支付新... 你有没有发现,现在的生活越来越离不开手机了?手机里装满了各种应用,而今天我要跟你聊聊一个特别实用的工...
鸿蒙系统是否还属于安卓,独立于... 你有没有想过,那个在我们手机上默默无闻的鸿蒙系统,它到底是不是安卓的“亲戚”呢?这个问题,估计不少手...
安卓系统手机用什么钱包,轻松管... 你有没有想过,你的安卓系统手机里装了那么多应用,但最离不开的,可能就是那个小小的钱包了。没错,就是那...
安卓系统能玩部落冲突吗,部落冲... 你有没有想过,安卓系统上的手机,是不是也能玩那款风靡全球的《部落冲突》呢?这款游戏自从推出以来,就吸...
智能机器人安卓系统,引领未来智... 你知道吗?在科技飞速发展的今天,智能机器人已经不再是科幻电影里的专属了。它们正悄悄地走进我们的生活,...
华为win10系统改装安卓系统... 你有没有想过,你的华为笔记本电脑里的Windows 10系统,能不能来个华丽变身,变成安卓系统呢?这...
旧电脑上安什么安卓系统,适配不... 你那台旧电脑是不是已经闲置好久了?别让它默默无闻地躺在角落里,给它来个华丽变身吧!今天,就让我来告诉...
安卓app语言跟随系统,随系统... 你知道吗?在手机世界里,有一个神奇的小功能,它就像你的贴身翻译官,无论你走到哪里,都能帮你轻松应对各...
惠城安卓系统降级在哪,揭秘降级... 你有没有遇到过手机系统升级后,发现新系统让你头疼不已,想回到那个熟悉的安卓系统呢?别急,今天就来告诉...