给出一个序列(长度>=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】水题,模拟的更多相关文章

  1. hdu 5532 Almost Sorted Array (水题)

    Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  2. hdu 5532 Almost Sorted Array(模拟)

    Problem Description We are all familiar with sorting algorithms: quick sort, merge sort, heap sort, ...

  3. HDU 5532 Almost Sorted Array (最长非递减子序列)

    题目链接 Problem Description We are all familiar with sorting algorithms: quick sort, merge sort, heap s ...

  4. HDU 5532——Almost Sorted Array——————【技巧】

    Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  5. hdu 5532 Almost Sorted Array nlogn 的最长非严格单调子序列

    Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  6. HDU - 5532 Almost Sorted Array (最长非严格单调子序列)

    We are all familiar with sorting algorithms: quick sort, merge sort, heap sort, insertion sort, sele ...

  7. hdu 5532 Almost Sorted Array

    http://acm.hdu.edu.cn/showproblem.php?pid=5532  题目大意: 给你一个不规则的序列,问是否能够通过删除一个元素使其成为一个有序的序列(递增或递减(其中相邻 ...

  8. CF451B Sort the Array 水题

    Codeforces Round #258 (Div. 2) Sort the Array B. Sort the Array time limit per test 1 second memory ...

  9. HDU 5538 L - House Building 水题

    L - House Building Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.ph ...

随机推荐

  1. HttpApplication实战大文件上传 (第四篇)

    一.Asp.net中的文件上传 在Asp.net 1.1中,文件在上传过程中将被全部保存在内存中,对于大文件来说,会造成内存空间的过度使用,可能会招致恶意攻击.为了解决这个问题,Asp.net在配置文 ...

  2. Dos命令---ipconfig

    Dos命令---ipconfig 作者:vpoet mail:vpoet_sir@163.com ipconfig是很常用的Dos命令,我们可以用ipconfig /?查看该命令的说明.在linux下 ...

  3. hdu 4502 吉哥系列故事——临时工计划_简单dp

    题意:        俗话说一分钱难倒英雄汉,高中几年下来,吉哥已经深深明白了这个道理,因此,新年开始存储一年的个人资金已经成了习惯,不过自从大学之后他不好意思再向大人要压岁钱了,只能把唯一的希望放到 ...

  4. Unity 扩展属性自定义绘制

    这么晚了准备睡觉的时候,去学习了一会. 发现一个标题好奇的点进去. 居然是自定义绘制属性.  在前几天这个问题把我难住了,没想到几分钟就能解决的问题. 我花了半天时间使用反射去解决...  如果我们想 ...

  5. java学习笔记day07

    1.throwable下面的子类分为两大类:Error 和 Exception 2.如果方法上有throws Exception,则必须对异常进行处理:  try{    需要检测异常代码     } ...

  6. RequireJs运行原理

    在require中,根据AMD(Asynchronous Module Definition)的思想,即异步模块加载机制,其思想就是把代码分为一个一个的模块来分块加载,这样无疑可以提高代码的重用. 在 ...

  7. 【TFS】增加组员,以及用户权限分配

    一.创建windows用户. 二.TFS ->组成员资格->双击 项目集合管理员->添加创建的Windows用户(最高权限) 三.设置权限: TFS权限的复杂,其实也不是很复杂,它只 ...

  8. eclipse安装svn插件,在输入url后,一直卡在in progress界面不懂。

    今天遇到上面的情况.网上找了半天都没有找到解决的办法.后来,仔细比对了一下我的eclipse版本和svn版本.发现svn版本真的太老了.用上新的svn后,立马就可以用了 svn - http://su ...

  9. 读取webconfig里面的appSetting和connectionString

    <appSettings> <add key="SiteURL" value="http://moss2007:7000" /> < ...

  10. synchronized关键字的用法

    synchronized用于给方法或者块加锁用的,只有获得该对象或者块的锁的对象才能够执行里面的代码,否则将阻塞在那里,等待该锁被释放,然后获得该锁继续执行.比如下面模拟售票的代码: /** * 模拟 ...