题目链接

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

题目描述

3547.特殊数字

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

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

输入格式

一个整数 n。

输出格式

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

数据范围

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

输入样例:

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 1≤q≤30,1≤x≤30。
对于 100% 的数据, 1 ≤ q ≤ 2 × 1 0 5 , 1 ≤ x ≤ 2 × 1 0 5 1≤q≤2×10^5,1≤x≤2×10^5 1≤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<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](1≤l≤r≤n),将 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} ap1​≤ap2​≤…≤apk​,其长度为 k。

输入格式

第一行一个整数 n。

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

输出格式

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

数据范围

对于 30% 的数据, 1 ≤ n ≤ 100 1≤n≤100 1≤n≤100。
对于 100% 的数据, 1 ≤ n ≤ 1 0 6 1≤n≤10^6 1≤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<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;
}

Acwing——第二场热身赛相关推荐

  1. 2018牛客网暑假ACM多校训练赛(第二场)E tree 动态规划

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round2-E.html 题目传送门 - 2018牛客多校赛第二场 E ...

  2. 第十二届蓝桥杯大赛软件赛省赛第二场【C++B组】

    自己参加的是第一次场的,打的很烂.做了一下第二场的题,我是真想骂街. 第二场普遍简单许多. 目录 A: 求余 [签到] B: 双阶乘 [签到] C: 格点 [签到题] D: 整数分解 [DP] E: ...

  3. python123平台作业答案第十二周_【2018年 网鼎杯CTF 第二场】红日安全-网鼎杯WriteUp(24日 更新:web详解)...

    本次比赛主要由红日安全ctf小组奋力拼搏,才可以拿到第二场第四的成绩.感谢他们的付出,才可以让我们看到精彩的wp 1.签到题 2.虚幻 题目提示汉信码.使用 binwalk 提取出 9 张图,拼接成如 ...

  4. 2012百度之星冬季赛第二场第二题 消去游戏I

    2012百度之星冬季赛第二场第二题 消去游戏I 题目: Alice和Bob又开始发明新游戏了,这回的名字叫消去游戏. 消去游戏的道具是一堆排成一行的积木,每个积木上面都有一个数字Ai.同时游戏也需要M ...

  5. ICPC网络赛第二场G Limit

    ICPC网络赛第二场G Limit 题意: 给你数组a和b,求解: 1≤n≤100000,−100≤ai,bi≤100,0≤t≤5.1≤n≤100000,−100≤a_{i},b_{i}≤100,0≤ ...

  6. icpc网络赛第二场K Meal

    icpc网络赛第二场K Meal 题意: 有n个人,n个菜, 现在n个人轮流吃菜,起初S中有n个菜,第i个人会在还没拿走的菜中随机选一个,拿走第j个菜的概率为ai,j∑k∈Sai,k\frac{a_{ ...

  7. Fake Maxpooling(2020多校第二场F)

    Fake Maxpooling(2020多校第二场F) 文章目录 题意: 题解: 代码: 题意: 一个n * m的矩阵,第i行第j列的值是lcm(i,j),然后给定一个 k * k的子矩阵(k< ...

  8. Duration(2020多校第二场D)

    Duration(2020多校第二场D) 文章目录 题意 题解 代码 首先,非常感谢出题人出这个题,避免了我全wa的尴尬 题意 求两个时间相差多少秒,两个时间为同一天 题解 全部转化成秒,然后求差 代 ...

  9. Boundary(2020多校第二场B)

    Boundary(2020多校第二场B) 文章目录 题意: 题解: 思路1: 代码: 思路二 代码 题意: 坐标平面有n个点(不与原点(0,0)重复),现考虑一个圆,(0,0)点在圆的边界,问这个圆的 ...

最新文章

  1. html5 子元素选择器,CSS子元素选择器 - HTML电子邮件
  2. c++ 使用vs2010调用 win32api
  3. Linux实现开机自动运行普通用户脚本
  4. 正则表达式及shell
  5. 机器学习(监督学习) 项目流程模板
  6. step6: item与pipeline
  7. 玩转PHP关联数组的10个技巧(3)
  8. Java JDK 源码结构
  9. 使用rsync无密码传输
  10. 【数据分析入门】R语言绘图语句总结
  11. 分析、归纳、综合、演绎
  12. android 过滤英文字符,Android编程之TextView的字符过滤功能分析
  13. Android软件开发用什么语言?
  14. ERP-企业资源计划
  15. 程序员老了怎么办?做什么好?
  16. Type.GetType()在跨程序集反射时返回null的解决方法
  17. 20、个人信息 - 小程序端开发 - 微擎小程序模块应用开发
  18. 去除广告插件多点(a.banner.doubleClick)
  19. 带地理信息的课程签到需求实现(使用现有软件)
  20. PHP开发-从零开始(附网站开发效果图)

热门文章

  1. easyrecovery2023永久免费版激活密钥,手把手教您用EasyRecovery快速恢复数据
  2. 【智能车学习】电磁循迹中的基本控制算法
  3. 运用 DRM 对流媒体文件加密
  4. 有什么修复老照片的方法
  5. Python练习册,每天一个小程序(十七)
  6. DELL R720系统内存指南
  7. Mac电脑好用软件推荐
  8. 结合SSE实现实时位置展示与轨迹展示
  9. ​三态总线与双向三态总线
  10. 数电技术基础大恶补02:逻辑代数