Codeforces Round #FF

  A.DZY Loves Hash

  hash函数 h(x) = x % p  输出第一次冲突的位置

#include<iostream>
#include<cstdio>
#include<cstdlib>using namespace std;const int maxn = 4000;int p, n;
bool inhash[maxn];int main()
{freopen("447A.in", "r", stdin);cin >> p >> n;for(int i = 0; i < n; i++) {long long t;cin >> t;if(!inhash[t % p])    inhash[t % p] = 1;else {cout << i+1 << endl;return 0;}}cout << -1 << endl;return 0;
}

  

  B.DZY Loves Strings

    对于一个字符串,每个字母有相应的权值,由这个公式计算f(s)

 

现在能够插入k个任意字母,要求使得新的字符串f(s')值最大

  字符串就是幌子,替换成数字,插入的字符很明显贪心一下取最大的,一开始也没发现规律,瞎搞的,题解的意思大概是:

  插入x到位置p之后,则增加的权值为x*p+Ws(p+1)+Ws(p+2)...(p以后每一个权值) -> x+x+x+x...+Ws(p+1)+Ws(p+2)...容易观察到其实是用x替换前p个Ws,而由于贪心策略,x >= Ws.所以上式要取最大,p应该取|s|,对于剩下k-1个x同理,最终转化为把p个x插入到最后端得到的f(s‘)

(这份代码没删除之前乱搞的部分,比较乱就不贴了)

(B都写不来。。。这绝壁回家养猪节奏!)

 

  C.DZY Loves Sequences

  咋一眼看像是dp,可是自己死活想不出来思路,O(N),结果是自己没自习审题,ai, ai+1, ai+2 连续的!

  大意是给你一个数列,最多修改一个数字,球得最长的单调递增子串(严格的)(连续的!!!)

  可以设想一下如果x是要修改的数字,a[x+1]-a[x-1]>1(因为是整数,严格单调),以x为界左边是一个以a[x-1]为尾的单调增,右边是a[x+1]为首单调增,我们可以预处理出这两边的长度,然后枚举每一个a[i](2~n-1),取max即可

  预处理过程就算是简单dp吧...以从左往右为例 f[i] = 1 (a[i] <= a[i-1])  或 f[i-1]+1 (a[i] > a[i-1]) 

 

(审题呐!英文不好容易漏细节...)

  

#include <iostream>
#include <cstdlib>
#include <cstdio>using namespace std;const int maxn = 100000+50;int n;
int a[maxn], r[maxn], l[maxn], f[maxn];int main()
{scanf("%d", &n);for(int i = 1; i <= n; i++)scanf("%d", a+i);for(int i = 1; i <= n; i++)f[i] = 1;l[1] = 1;for(int i = 2; i <= n; i++)l[i] = (a[i] > a[i-1]? l[i-1]+1: 1);r[n] = 1;for(int i = n-1; i >= 1; i--)r[i] = (a[i] < a[i+1]? r[i+1]+1: 1);for(int i = 1; i <= n; i++) {if(i >= 2)  f[i] = max(f[i], 1+l[i-1]);if(i <= n-1)    f[i] = max(f[i], 1+r[i+1]);if(a[i+1] - a[i-1] > 1) f[i] = max(f[i], 1+r[i+1]+l[i-1]);}int ans = 0;for(int i = 1; i <= n; i++)ans = max(ans, f[i]);printf("%d\n", ans);    return 0;
}

 

  

转载于:https://www.cnblogs.com/gemmeg/p/3854371.html

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

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

相关文章

面试突击 | Redis 如何从海量数据中查询出某一个 Key?视频版

作者 | 王磊面试突击 | 第 001 期1 考察知识点本题考察的知识点有以下几个&#xff1a;Keys 和 Scan 的区别Keys 查询的缺点Scan 如何使用&#xff1f;Scan 查询的特点2 解答思路 Keys 查询存在的问题Scan 的使用Scan 的特点3 Keys 使用相关 1&#xff09;Keys 用法如下2&#…

面经 | 我是如何拿到阿里offer的?附面试题+视频

作者 | rhwayfunn来源 | http://dwz.win/2JK本文来自 rhwayfunn 本人自述&#xff1a;拿到阿里实习offer&#xff0c;经历了5次面试&#xff0c;其中4轮技术面&#xff0c;1轮HR面试。在这里分享一下自己的面试经验和学习总结。希望能够帮助更多的小伙伴。我本科毕业于中南大学…

SCOM 2012知识分享-9:配置警报解决状态

适应平台&#xff1a;System Center 2012 RTM/SP1-------------------------------------------------------------------------------------------------------------设置警报的解决状态在操作控制台中&#xff0c;请单击监视。单击任何视图&#xff0c;将显示警告&#xff0c…

Linux debian ubuntu安装GIMP软件

一、GIMP简介 名称由GNU Image Manipulation Program&#xff08;GNU图像处理程序&#xff09;的首字母组成&#xff0c;是一个自由及开放原始码的点阵图图像编辑器&#xff0c;用于图像照片润饰及编辑、自由绘图、调整大小、裁剪、相片蒙太奇、装换图像格式以及其他专业任务。…

面试突击 002 | Redis 是如何处理已过期元素的?

1 面试题 Redis 如何处理已过期的元素&#xff1f;2 涉及知识点 此问题涉及以下知识点&#xff1a;过期删除策略有哪些&#xff1f;这些过期策略有哪些优缺点&#xff1f;Redis 使用的是什么过期策略&#xff1f;Redis 是如何优化和执行过期策略的&#xff1f;3 答案 常见的过期…

Linux debian安装PyCharm教程、配置pyqt5开发环境

一、PyCharm下载 首先需要下载一个PyCharm社区版压缩包&#xff1a;pycharm-community-2021.1.3.tar.gz。 Linux PyCharm社区版下载 二、PyCharm安装 1.我们最好在普通用户下解压并启动这个软件。如果你在超级用户下启动&#xff0c;你的pycharm就不能输入中文了&#xff0c…

10大iOS开发者最喜爱的类库

该10大iOS开发者最喜爱的库由“iOS辅导团队”成员Marcelo Fabri组织投票选举而得&#xff0c;参与者包括开发者团队&#xff0c;iOS辅导团队以及行业嘉宾。每个团队都要根据以下规则选出五个最好的库&#xff1a;1&#xff09;不能投自己写的库&#xff1b;2&#xff09;排除大…

面试突击第 3 期 | Redis 如何实现查询附近的人?视频实战版

这是我的第 33 篇原创文章作者 | 王磊 &#xff08;javacn666&#xff09;1 面试问题 Redis 如何实现查询附近的人&#xff1f;2 相关面试问题 Redis 中如何操作位置信息&#xff1f;GEO 底层是如何实现的&#xff1f;如何在程序实现查询附近的人&#xff1f;在实际使用中需要注…

Linux debian ubuntu的PyCharm无法正常输入中文

debian ubuntu中 PyCharm 当全拼输入2~3个汉字时&#xff0c;会被强行打断&#xff0c;然后就无法继续输入(也无法切换中英文)&#xff0c;并且汉字下会有下划线。 解决方案&#xff1a; 1.点击PyCharm菜单 “Help ->Edit Custom VM options…” 2.添加 -Drecreate.x11.in…

面试突击 004 | 如何排查 Redis 中的慢查询?视频实战篇

这是我的第 34 篇原创文章作者 | 老王&#xff08;javacn666&#xff09;1 面试题如何排查 Redis 中的慢查询&#xff1f;2 涉及相关问题 Redis 中有没有慢查询排查工具或者相关排查手段&#xff1f;慢查询日志都包含哪些信息&#xff1f;慢查询的相关配置项有哪些&#xff1f;…

[转]Android 之 Window、WindowManager 与窗口管理

这篇是对前两天研究的悬浮窗的内容的一个小小的资料整理吧。首先是转载一篇介绍Android窗口的内容&#xff0c;觉得写得不错&#xff1a;http://blog.csdn.net/xieqibao/article/details/6567814 为防止丢失还是把内容也拷一遍吧(*^__^*) 嘻嘻…… 其实在android中真正展示给用…

面试突击 005 | Redis 是如何实现高可用的?它的实现方式有哪些?「视频版」

这是我的第 35 篇原创文章作者 | 老王&#xff08;javacn666&#xff09;这部视频的录制、剪辑、做 PPT、写文稿大约花费了 5 个小时的时间&#xff0c;希望这种形式能被更多的人喜欢&#xff0c;希望这篇文章会给你带来更多的价值。1 面试题 Redis 是如何实现高可用的&#xf…

Linux debian安装和使用Navicat16 for MySQL

Navicat是一套快速、可靠并价格相当便宜的数据库管理工具&#xff0c;专为简化数据库的管理及降低系统管理成本而设。它的设计符合数据库管理员、开发人员及中小企业的需要。Navicat 是以直觉化的图形用户界面而建的&#xff0c;让你可以以安全并且简单的方式创建、组织、访问并…

windosw7 Hosts文件的位置

2019独角兽企业重金招聘Python工程师标准>>> 1.Hosts文件的位置 &#xff1a; C:\Windows\System32\drivers\etc\Hosts 一般个人电脑都在这位置&#xff0c; 例如&#xff1a;118.144.78.38 www.51cto.com ip 域名 # Copyright…

Redis都不懂?就别去面试了!聊聊我的Redis新专栏「视频版」

前不久&#xff0c;有一个读者在后台留言&#xff0c;说他面试 Java 开发工程师岗位时&#xff0c;居然大部分的面试问题都是关于 Redis &#xff0c;他都差点都忘记了自己应聘的是 Java 工程师了。而然这种现象在现在的后端面试中很常见&#xff0c;对 Redis 的掌握已经变成了…

Linux Debian Python弹出信息框、警告框和询问框

利用PyCharm开发平台和Python编程语言开发PyQt5界面程序&#xff0c;有时需要弹出信息框、警告框和咨询框&#xff0c;使用win32api和win32con在windows系统可以&#xff0c;但是在Linux系统不可以。为了解决这个问题&#xff0c;可以使用QMessageBox。 # pip install pywin32…

面试突击 | Redis 如何从海量数据中查询出某一个 Key?附视频

1 考察知识点 本题考察的知识点有以下几个&#xff1a; Keys 和 Scan 的区别Keys 查询的缺点Scan 如何使用&#xff1f;Scan 查询的特点 2 解答思路 Keys 查询存在的问题Scan 的使用Scan 的特点 3 Keys 使用相关 1&#xff09;Keys 用法如下 2&#xff09;Keys 存在的问题…

分享两个好用的nosql GUI工具

redis: 真是千呼万唤始出来&#xff0c;终于有了redis gui 谢谢作者&#xff0c;但中文乱码问题貌似还没有解决呀&#xff01; https://github.com/caoxinyu/RedisClient mongoDB: MongoVUE这个还是很完善的 http://www.mongovue.com/ 转载于:https://www.cnblogs.com/tankaixi…

Linux Debian11安装MySQL8详细教程

一、下载MySQL Community Server Debian11使用了MariaDB 在APT的软件包存储库中并没有mysql,在这里下载MySQL Community Server 然后选择Debian时会出现建议使用 Mysql APT Repository。所以我们下载安装 Mysql APT Repository 的方式更新 APT Repository 之后使用 dpkg -i安…

HashMap 为什么会导致 CPU 100%?文章看不懂?来看这个视频吧!——面试突击 006 期...

无论是在实际工作中还是在面试中&#xff0c;HashMap 无疑是使用频率最高的知识点之一&#xff0c;所以我们需要搞懂每一个关于 HashMap 的知识点才行。哈喽&#xff0c;大家好&#xff0c;我是老王&#xff0c;欢迎来到 Java 面试突击&#xff0c;我们今天来开始第 6 期的内容…