【HDU 5532 Almost Sorted Array】水题,模拟
给出一个序列(长度>=2),问去掉一个元素后是否能成为单调不降序列或单调不增序列。
对任一序列,先假设其可改造为单调不降序列,若成立则输出YES,不成立再假设其可改造为单调不增序列,若成立则输出YES,不成立则输出NO。
由于持平不影响整体单调性,为了直观,我在以下把“不降”称为“递增/升序”,把“不增”称为“递减/降序”。
递增和递减是对称的,这里先考虑递增,递减改个符号和最值就好。
我们把为维护单调性而去掉的那个点称为“坏点”。由题目的要求,“可改造”可等价于“只存在一个坏点”。
对于“坏点”的判断,我们可以先找出是否只存在一组“逆序”。
对于“almosted sorted”递增序列,只存在一组逆序无非以下四种情况(这里先不考虑逆序在边界)。

现在考虑逆序在边界的情况。由于a[]数组元素下标是1~n,而此题1<=ai<=100000,那么对于递增序列,可把a[0]设为1、把a[n+1]设为100000作为首尾哨兵节点,一定不会破坏整体单调性;递减序列做对称的处理。这样边界也可以像中间一样处理。
由于三种情况满足一种即可,而第二种可以看作第三种和第四种的交集,故只需按照第三种和第四种的情况对a[]数组各进行一次遍历,满足一种即可输出YES。
对于坏点的处理,我们采用“当它不存在”的策略,所以首次遇到坏点,忽略它,再次遇到坏点,则此种情况不成立。
至于如何由“逆序”推出“坏点”,并实现几种情况的判断,我们遍历i:0~n,对于第一对逆序a[i]>a[i+1],我们可以:
先采取“左归”(第三种),即把a[i]当作坏点,判断a[i-1]和a[i+1]是否升序(若不升序则相当于构成了第二对逆序,出现第二个坏点);
若左归不成立,再采取“右归”(第四种),即把a[i+1]当坏点,同理判断a[i]和a[i+2]是否升序。
11.23更新代码如下,更加简化,速度更快
#include <cstdio>
using namespace std; const int MAX_N=;
const int MIN_A=;
const int MAX_A=;
int T;
int n;
int a[MAX_N];
int flag;
int fix_cnt; int main()
{
freopen("5532.txt","r",stdin);
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
}
//升序
flag=;//假设去掉最多一个元素后整体降序
fix_cnt=;
a[]=MIN_A;
a[n+]=MAX_A;
for(int i=;i<=n-;i++)
{
if(a[i]<=a[i+]) continue;
fix_cnt++;
if(fix_cnt<=&&(a[i-]<=a[i+]||a[i]<=a[i+])) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
//降序
flag=;//假设去掉最多一个元素后整体降序
fix_cnt=;
a[]=MAX_A;
a[n+]=MIN_A;
for(int i=;i<=n-;i++)
{
if(a[i]>=a[i+]) continue;
fix_cnt++;
if(fix_cnt<=&&(a[i-]>=a[i+]||a[i]>=a[i+])) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
printf("NO\n");
}
return ;
}
先前版本代码如下:
#include <cstdio>
using namespace std; const int MAX_N=;
const int MIN_A=;
const int MAX_A=;
int T;
int n;
int in[MAX_N],de[MAX_N];
int flag;
int fix_cnt; int main()
{
freopen("5532.txt","r",stdin);
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&in[i]);
de[i]=in[i];
} //升序的情况
in[]=MIN_A;
in[n+]=MAX_A;
flag=;//假设去掉最多一个元素后整体升序
fix_cnt=;
for(int i=;i<=n-;i++)
{
if(in[i]<=in[i+]) continue;
fix_cnt++;//左归的情况
if(fix_cnt<=&&in[i-]<=in[i+]) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
flag=;
fix_cnt=;
for(int i=;i<=n-;i++)
{
if(in[i]<=in[i+]) continue;
fix_cnt++;//右归的情况
if(fix_cnt<=&&in[i]<=in[i+]) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
//降序的情况
de[]=MAX_A;
de[n+]=MIN_A;
flag=;//假设去掉最多一个元素后整体降序
fix_cnt=;
for(int i=;i<=n-;i++)
{
if(de[i]>=de[i+]) continue;
fix_cnt++;//左归的情况
if(fix_cnt<=&&de[i-]>=de[i+]) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
flag=;
fix_cnt=;
for(int i=;i<=n-;i++)
{
if(de[i]>=de[i+]) continue;
fix_cnt++;//右归的情况
if(fix_cnt<=&&de[i]>=de[i+]) continue;
flag=;
break;
}
if(flag)
{
printf("YES\n");
continue;
}
printf("NO\n");
}
return ;
}
【HDU 5532 Almost Sorted Array】水题,模拟的更多相关文章
- hdu 5532 Almost Sorted Array (水题)
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- hdu 5532 Almost Sorted Array(模拟)
Problem Description We are all familiar with sorting algorithms: quick sort, merge sort, heap sort, ...
- HDU 5532 Almost Sorted Array (最长非递减子序列)
题目链接 Problem Description We are all familiar with sorting algorithms: quick sort, merge sort, heap s ...
- HDU 5532——Almost Sorted Array——————【技巧】
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- hdu 5532 Almost Sorted Array nlogn 的最长非严格单调子序列
Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- HDU - 5532 Almost Sorted Array (最长非严格单调子序列)
We are all familiar with sorting algorithms: quick sort, merge sort, heap sort, insertion sort, sele ...
- hdu 5532 Almost Sorted Array
http://acm.hdu.edu.cn/showproblem.php?pid=5532 题目大意: 给你一个不规则的序列,问是否能够通过删除一个元素使其成为一个有序的序列(递增或递减(其中相邻 ...
- CF451B Sort the Array 水题
Codeforces Round #258 (Div. 2) Sort the Array B. Sort the Array time limit per test 1 second memory ...
- HDU 5538 L - House Building 水题
L - House Building Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.ph ...
随机推荐
- Merge k Sorted Lists 解答
Question Merge k sorted linked lists and return it as one sorted list. Analyze and describe its comp ...
- Remove Nth Node From End of List 解答
Question Given a linked list, remove the nth node from the end of list and return its head. For exam ...
- 静态链表实现 (A-B)U(B-A)
图中黄色部分为(A-B)U(B-A)的实际意义,用结构数组做静态链表来实现该表达式 大致流程是先建立A链表,接着将挨个输入的B中元素在A链表中遍历.如果没找到,就加到A链表结尾下标为endpointe ...
- MySql 取一天的开始时间和结束时间
-- 取一开的开始时间 SELECT str_to_date(DATE_FORMAT(NOW(),'%Y-%m-%d'),'%Y-%m-%d %H:%i:%s'); -- 取第二天的开始时间 sele ...
- ERROR: HHH000388: Unsuccessful: create table
做SSH整合的时候,总是出现错误信息: 类似这样: : HHH000388: Unsuccessful: create table right (right_code varchar(255) not ...
- C语言头文件组织
一.全局变量单独编写(很值得借鉴). 一般习惯将不同功能模块放到一个头文件和一个C文件中. 例如是写一些数学计算函数: //mymath.h #ifndef _mymath_H #define _my ...
- iOS 字体设置
使用无衬线字体 body { font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif; } iOS 4 ...
- linux配置yum源
yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...
- html5的改变
html5的改变 新增的元素 新增的结构元素 section.article.aside.header.hgroup.footer.nav.figure 新增的其他元素 video.audio.emb ...
- Javascript进阶篇——(流程控制语句)笔记整理
做判断(if语句)if语句是基于条件成立才执行相应代码时使用的语句.语法: if(条件){ 条件成立时执行代码 } 例子:假设你应聘web前端技术开发岗位,如果你会HTML技术,你面试成功,欢迎加入公 ...