ACM_买粽子(UVA唯一的雪花)
Problem Description:
端午节快到了,小蛋准备到集市上买粽子。于是周六这天,小蛋和舍友搭着公交到了西南市场。说来也怪,这天集市上就只有n个人在卖粽子,整齐地排成一列,而且第i(1<=i<=n)个人前面有Xi个粽子堆在一起。小蛋这人平时很大方,买东西也很讲究,这次就想自掏腰包,准备买很多粽子送给同学和老师们吃。那么问题来了,有n个人在卖粽子,怎么个买法呢?小蛋就想在n个人中连续地选择k个相邻的人买他们全部的粽子,要求所选的这k个连续相邻的人各自卖的粽子数量不能有相同的个数,并且使得k最大。
Input:
输入有多组数据
第一行输入一个整数n(0<n<=100000),表示集市上有n个人在卖粽子。
第二行输入n个整数,第i个数表示第i个人卖的粽子数量Xi(0 < Xi <= 1000)。
Output:
输出符合条件的最大值k,每个输出占一行
Sample Input:
7
3 2 4 1 3 2 3
5
1 6 3 1 2
Sample Output:
4
4
解题思路:滑动窗口,尺取法思想。找到一个最长的连续子序列,使得里面的元素都不相同。set容器维护,时间复杂度是O(nlog(n))。紫书讲得好:假设序列元素从0开始编号,所求连续子序列的左端点为L,右端点为R。从R=0开始不断增加R,相当于把所求序列的右端点往右延伸。当无法延伸(即A[R+1]在子序列A[L~R]中出现过)时,只需增大L,并且继续延伸R。既然当前的A[L~R]是可行解,L增大之后必然还是可行解,所以不必减少R,继续增大即可。
AC代码一之set:
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+;
int n,x[maxn],l,r,ans;set<int> st;
int main(){
while(~scanf("%d",&n)){
for(int i=;i<n;++i)scanf("%d",&x[i]);
l=r=ans=;st.clear();
while(r<n){
while(r<n&&!st.count(x[r]))st.insert(x[r++]);
ans=max(ans,r-l);
st.erase(x[l++]);
}
printf("%d\n",ans);
}
return ;
}
AC代码二之map:思路和操作跟上面一样,非常巧妙地处理了区间中不同元素的下标。
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+;
int n,l,r,ans,x,last[maxn];map<int,int> cur;
int main(){
while(~scanf("%d",&n)){
memset(last,,sizeof(last));cur.clear();
for(int i=;i<n;++i){
scanf("%d",&x);
if(!cur.count(x))last[i]=-;///如果还没出现,则标记为-1
else last[i]=cur[x];///否则记录上一次出现的下标
cur[x]=i;///更新当前x的坐标
}
l=r=ans=;
while(r<n){
while(r<n&&last[r]<l)r++;///如果当前last[r]!=l说明该区间中所有元素都不同,则继续向右延伸r,否则l++,即左端点向右蠕动
///cout<<l<<endl;
ans=max(ans,r-l);
l++;
}
printf("%d\n",ans);
}
return ;
}
/*
i 0 1 2 3 4 5 6
A[i] 3 2 4 1 3 2 3
last[i] -1 -1 -1 -1 0 1 4
*/
ACM_买粽子(UVA唯一的雪花)的更多相关文章
- Uva 11572 唯一的雪花
题目链接:https://uva.onlinejudge.org/external/115/11572.pdf 题意:找到一个尽量长的连续子序列 Al ~ AR ,使得该序列没有相同的元素. 分析:枚 ...
- UVa 11572 唯一的雪花(滑动窗口)
https://vjudge.net/problem/UVA-11572 题意:输入一个长度为n的序列A,找到一个尽量长的连续子序列,使得该序列中没有相同的元素. 思路:很简单的题,也没啥好解释的了. ...
- UVa 11572 唯一的雪花(优化策略)
题目描述: 输入一个长度为n(n<=1000000)的序列A, 找到一个尽量长的连续子序列A(L)-->A(R),是的该序列中没有相同的元素. 输入: T:代表组数 n:代表有n个数 这一 ...
- UVA - 11572 Unique Snowflakes(唯一的雪花)(滑动窗口)
题意:输入一个长度为n(n <= 10^6)的序列A,找到一个尽量长的连续子序列AL~AR,使得该序列中没有相同的元素. 分析: 法一:从r=0开始不断增加r,当a[r+1]在子序列a[l~r] ...
- 全局唯一Id:雪花算法
雪花算法-snowflake 分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的. 有 ...
- [ACM_水题] UVA 11729 Commando War [不可同时交代任务 可同时执行 最短完成全部时间 贪心]
There is a war and it doesn't look very promising for your country. Now it's time to act. You have a ...
- [ACM_水题] UVA 11292 Dragon of Loowater [勇士斗恶龙 双数组排序 贪心]
Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into a major problem. The shor ...
- [ACM_水题] UVA 12502 Three Families [2人干3人的活后分钱,水]
Three Families Three families share a garden. They usually clean the garden together at the end o ...
- 集训第四周(高效算法设计)K题 (滑窗问题)
UVA 11572 唯一的雪花 题意:给你从1到n的数组,要求求得其中的最长连续不重复子序列,经典的滑窗问题,方法是维护一个窗口,设置左框和右框,然后不断的进行维护和更新 方法一: #include& ...
随机推荐
- Scrapy爬虫框架 基础
1< scrapy的安装 命令行安装 pip install scrapy <常见错误是缺少 wim32api 安装win32api pip install pywin32 <还有就 ...
- C3P0数据库连接池使用方法
一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...
- BZOJ 1941: [Sdoi2010]Hide and Seek KDtree + 估价函数
Code: #include<bits/stdc++.h> #define maxn 200000 #define inf 1000000000 using namespace std; ...
- C++入职学习篇--代码规范(持续更新)
C++入职学习篇--代码规范(持续更新) 一.头文件规范 在头文件中大家一般会定义宏.引入库函数.声明.定义全局变量等,在设计时最后进行分类,代码示范(自己瞎琢磨的,请多多指点): #ifndef T ...
- 39.date hitogram基础知识
主要知识点: date hitogram之统计每月电视销量 上一节讲到histogram,他是以数值进行分组.本节讲到以日期进行bucket分组操作,也就是说把连续的日期变成离散的日期区间,然 ...
- Python - 模块(二)
目录 Python - 模块(二) re re下面的方法 logging os Python - 模块(二) re re模块提供了正则表达式的相关操作 主要字符介绍: . 通配符,除了换行符之外的任意 ...
- 一个电商项目的Web服务化改造5:面向服务的分层架构设计(有图有真相)
最近一直在做一个电商项目,需要把原有单系统架构的项目,改造成基于服务的架构,SOA. 有点挑战,做完了,会有很大进步. 本篇,以我亲自画的3个图,阐述一下架构设计. 一.分层架构-总体图 ...
- 大专生自学Python到找到工作的心得
先做个自我介绍,我13年考上一所很烂专科民办的学校,学的是生物专业,具体的学校名称我就不说出来献丑了.13年我就辍学了,我在那样的学校,一年学费要1万多,但是根本没有人学习,我实在看不到希望,我就退学 ...
- 【codeforces 767A】Snacktower
[题目链接]:http://codeforces.com/contest/767/problem/A [题意] 每天掉一个盘子下来;盘子有大小从1..n依次增大n个盘子; 然后让你叠盘子; 最底层为n ...
- 【ACM】nyoj_47_过桥问题_201308151616
过河问题时间限制:1000 ms | 内存限制:65535 KB 难度:5描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的 ...