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

Codeforces Round #FF相关推荐

  1. Codeforces Round FF(Div. 2)

    layout: post title: Codeforces Round FF(Div. 2) author: "luowentaoaa" catalog: true tags: ...

  2. Codeforces Round #FF (Div. 1) A. DZY Loves Sequences

    原题链接:http://codeforces.com/problemset/problem/446/A 题意:给一个长度为n的序列,最多可以修改一个位置的数,求最长连续上升子序列. 题解:当a[i+1 ...

  3. Codeforces Round #FF (Div. 2) D. DZY Loves Modification 贪心+优先队列

    链接:http://codeforces.com/problemset/problem/447/D 题意:一个n*m的矩阵.能够进行k次操作,每次操作室对某一行或某一列的的数都减p,获得的得分是这一行 ...

  4. Codeforces Round #FF 446 C. DZY Loves Fibonacci Numbers

    參考:http://www.cnblogs.com/chanme/p/3843859.html 然后我看到在别人的AC的方法里还有这么一种神方法,他预先设定了一个阈值K,当当前的更新操作数j<K ...

  5. Codeforces Round #FF (Div. 2) A.DYZ Loves Hash

    水题.题目大意为输入一个p,n,再输入n组数据,每组数据对p取余,当和前面相同时,发现冲突,记下第几组,找到最后一组没有找到和前面一样的输出-1. *可以采用一个标记数组,就变得很简单了. A. DZ ...

  6. Codeforces Round #FF (Div. 2) B.DYZ Loves Strings

    *思路为对26个字母的价值进行排序,找到最大的价值,加最大的价值的字母往后放,价值最大. B. DZY Loves Strings time limit per test 1 second memor ...

  7. Codeforces Round #FF (Div. 2)C.DYZ Loves Sequence

    一道类似求严格递增子序列的题目.这道题可以改变一个数成任意数,使得严格递增子序列增加. *思路:两个标记数组from[i],to[i];from[i]的含义是从i出发的最长的严格递增序列长度,to[i ...

  8. Codeforces Round #453 (Div. 1) D. Weighting a Tree 构造 + dfs树

    传送门 文章目录 题意: 思路: 题意: 给你一颗nnn个点的图,每个点都有一个点权cic_ici​,要求你给每个边赋一个权值kik_iki​,要求对于每个点与他相连的边的权值之和等于这个点的点权ci ...

  9. Codeforces Round #756 (Div. 3)

    Codeforces Round #756 (Div. 3) A. Make Even 思路:如果末尾是偶数,不需要操作:如果开头是偶数,一次操作,即全翻转:如果开头和末尾都是 奇数,判断里面是否有偶 ...

最新文章

  1. CSS之布局(外边距的折叠)
  2. 新手安装ruby on rails(ror)的成功必备手册
  3. STM32CubedMX 下载与安装
  4. DevExtreme 学习应用[1]
  5. 低价购买(洛谷 1108)
  6. 配置hadoop集群
  7. apache虚拟主机名不区分大小写的解决办法
  8. sql server死锁_如何报告SQL Server死锁事件
  9. 安卓手机计算器应用java_安卓体重计算器java源程序 使用Intent在Activity间传输数据...
  10. Webpack配置问题
  11. length与length()
  12. TIPTOP 智能仓库扫描系统解决方案
  13. nginx过滤HttpHeader的 中划线
  14. CDN基于谷歌开源Katran四层负载均衡方案的应用 - 原理篇
  15. 解决vc6卡死的办法就是打上官方的原版VC6sp6补丁|VS6sp6补丁
  16. 互联网思维方式(一)
  17. exceljs 导入导出 excel 文件
  18. spring事务5个隔离界别和7钟传播行为
  19. matlab 吸引域,科学网—非线性方程组的吸引域和分界线 - 王龙飞的博文
  20. 公务员笔试——侵占罪、职务侵占罪和贪污罪的区别

热门文章

  1. java substring截取字符串_java基础教程之字符串的介绍,比较重要的一个知识点【下】...
  2. php escapeshellcmd,利用/绕过 PHP escapeshellarg/escapeshellcmd函数
  3. MySQL的乱码解决方案
  4. adc0809引脚图及功能_80C51单片机的引脚及其功能介绍
  5. Linux输入密码接口,Linux下搭建接口自动化测试平台
  6. java接口允许ajax访问_服务允许AJAX请求,允许跨域请求
  7. a4纸网页打印 table_打印模板不愁人,你还在打印单调的A4纸吗?
  8. mysql 先删后增 更新_MySQL 高级操作——新增数据、更新数据、删除数据、查询数据...
  9. 手写table用ajax遍历,原生js把数据循遍历到前端table
  10. 传统的6d位姿估计fangfa1_李飞飞团队最新论文:基于anchor关键点的类别级物体6D位姿跟踪...