17.6 给定一个整数数组,编写一个函数,找出索引m和n,只要将m和n之间的元素排好序,整个数组就是有序的。注意:n越小越好,也就是说,找出符合条件的最短序列。

解法:

开始解题之前,让我们先确认一下答案会是什么样的。如果要找的是两个索引,这表明数组中间有一段有待排序,其中数组开头和末尾部分是排好序的。

现在,我们借用下面的例子来解决此题:

1,2,4,7,10,11,7,12,6,7,16,18,19

首先映入脑海的想法可能是,直接找出位于开头的最长递增子序列,以及位于末尾的最长递增子序列。

左边:1,2,4,7,10,11

中间:7,12

右边:6,7,16,18,19

很容易就能找出这些子序列,只需从数组最左边和最右边开始,向中间查找递增子序列。一旦发现元素大小顺序不对,那就是找到了递增/递减子序列的两头。

但是,为了解决这个问题,还需要对数组中间部分进行排序,只要将中间部分排好序,数组所有元素便是有序的。具体来说,就是一下判断条件必须为真:

//左边所有元素都要小于中间所有元素

min(middle)>end(left)

//中间所有元素都要小于右边的所有元素

max(middle)<start(right)

或者,换句话说,对于所有元素:

left<middle<right

实际上,上例的这个条件绝对不可能成立。根据定义,中间部分的元素是无序的。而在上面的例子中,left.end>middle.start且middle.end>right.start一定成立。这样一来,只排序中间部分并不能让整个数组有序。

不过,我们还可以缩减左边和右边的子序列,直到先前的条件成立为止。

令min等于min(middle),max等于max(middle).

对左边部分,我们先从这个子序列的末尾开始,并向左移动,直到找到元素索引i使得array[i]<min;找到后只需排序中间部分,就能让数组的那部分有序。

然后,对右边部分进行类似操作。

C++实现代码:

#include<iostream>
using namespace std; int findEndOfLeftSubsequence(int array[],int n)
{
int i;
for(i=;i<n;i++)
{
if(array[i]<array[i-])
return i-;
}
return n-;
} int findEndOfRightSubsequence(int array[],int n)
{
int i;
for(i=n-;i>=;i--)
{
if(array[i]>array[i+])
return i+;
}
return ;
} int shrinkLeft(int array[],int n,int min_index,int start)
{
int comp=array[min_index];
cout<<comp<<endl;
int i;
for(i=start-;i>=;i--)
{
if(comp>=array[i])
return i+;
}
return ;
} int shrinkRight(int array[],int n,int max_index,int start)
{
int comp=array[max_index];
cout<<comp<<endl;
for(int i=start;i<n;i++)
{
if(comp<=array[i])
return i-;
}
return n-;
} void findUnsortedSequence(int array[],int n)
{
int end_left=findEndOfLeftSubsequence(array,n);
cout<<end_left<<endl;
int start_right=findEndOfRightSubsequence(array,n);
cout<<start_right<<endl;
int min_index=end_left+;
if(min_index>=n)
return;
int max_index=start_right-;
for(int i=end_left;i<=start_right;i++)
{
if(array[i]<array[min_index])
min_index=i;
if(array[i]>array[max_index])
max_index=i;
}
cout<<array[min_index]<<" "<<array[max_index]<<endl;
int right_index=shrinkRight(array,n,max_index,start_right);
int left_index=shrinkLeft(array,n,min_index,end_left);
cout<<left_index<<" "<<right_index<<endl;
} int main()
{
int arr[]={,,,,,,,,,,,};
findUnsortedSequence(arr,);
}

careercup-中等难度 17.6的更多相关文章

  1. OC语言实现中等难度通讯录

    实现中等难度通讯录.需求: 1.定义联系⼈人类Contact.实例变量:姓名(拼⾳音,⾸首字⺟母⼤大写).性别.电话号码. 住址.分组名称.年龄.⽅方法:⾃自定义初始化⽅方法(姓名.电话号码).显⽰示 ...

  2. careercup-中等难度 17.12

    17.12 设计一个算法,找出数组中两数之和为指定值的所有整数对. 解答 时间复杂度O(n)的解法 我们可以用一个哈希表或数组或bitmap(后两者要求数组中的整数非负)来保存sum-x的值, 这样我 ...

  3. careercup-中等难度 17.11

    17.11 给定rand5(),实现一个方法rand7().也即,给定一个产生0到4(含)随机数的方法,编写一个产生0到6(含)随机数的方法. 解法: 这个函数要正确实现,则返回0到6之间的值,每个值 ...

  4. careercup-中等难度 17.9

    17.9 设计一个方法,找出任意指定单词在一本书中的出现频率. 解法: 1 单次查询 遍历这本书的每个单词,计算给定单词出现的次数.时间复杂度O(n),我们无法继续优化它,因为书中的每个单次都需要访问 ...

  5. careercup-中等难度 17.8

    17.8 给定一个整数数组(有正数和负数),找出总和最大的连续序列,并返回总和. 解法: 就是求连续子序列的和最大,不过存在一个问题: 假设整个数组都是负数,怎么样才是正确的行为呢?看看这个简单的数组 ...

  6. careercup-中等难度 17.7

    17.7 给定一个整数,打印该整数的英文描述(例如“One Thousand,Two Hundred Thirty Four”). 解法: 举个例子,在转换19 323 984时,我们可以考虑分段处理 ...

  7. careercup-中等难度 17.5

    17.5 写一个函数来模拟游戏. 游戏规则如下: 4个槽,里面放4个球,球的颜色有4种,红(R ),黄(Y),绿(G),蓝(B).比如, 给出一个排列RGGB,表示第一个槽放红色球,第二和第三个槽放绿 ...

  8. careercup-中等难度 17.4

    17.4 编写一个方法,找出两个数字中最大的那一个.不得使用if-else或其他比较运算符. 解法: 我们可以通过一步步的分析来将需要用到的if-else和比较操作符去掉: If a > b, ...

  9. careercup-中等难度 17.3

    17.3 写一个算法计算n的阶乘末尾0的个数? 解答: 首先,算出n的阶乘的结果再去计算末尾有多少个0这种方法是不可取的, 因为n的阶乘是一个非常大的数,分分种就会溢出.我们应当去分析, 是什么使n的 ...

随机推荐

  1. SCOI2010 and SXOI2014 股票交易(DP)

    明显的单调队列…… 但下面的程序一直有bug 附上题解:http://blog.csdn.net/njlcazl/article/details/8611042 附上我的代码: var head,ta ...

  2. 使用Zxing实现扫二维码描

    1.集成Zxing.bar 2.复制代码到项目中 3.修改 MipacActivityCapture.java  的扫描结果方法 handleDecode() /** * 处理扫描结果,实现活动页面跳 ...

  3. 网站资料收集 主要查看js的学习部分

    1.Asp.Net MVC3.0基本的简单的可能都会用,更深入的使用还需加深研究,之后希望对MVC4.0和5.0进行对比学习,暂时看到@葡萄城控件技术团队博客的MVC5系列正在继续http://www ...

  4. [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件

    页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...

  5. 单点登录系统(SSO)的开发思路

    单点登录并不是一个新鲜的玩意儿,比较官方的解释是企业业务整合的解决方案之一,通俗来讲SSO就是一个通用的用户中心,国内比较流行的UCenter就是一套单点登录解决方案.而近期以CSDN明文存储用户密码 ...

  6. 明修栈道,暗渡陈仓----之私募一哥徐翔新玩法 z

    前言:去年以来,因徐翔和宁电突然举牌资质平平的 000692 惠天热电,引起本人的兴趣,陆陆续续花了比较多的时间和精力去研究和跟踪000692惠天热电,期间也两次亲自去沈阳调研,从一些台前幕后人士那里 ...

  7. A Fast Priority Queue Implementation of the Dijkstra Shortest Path Algorithm

    http://www.codeproject.com/Articles/24816/A-Fast-Priority-Queue-Implementation-of-the-Dijkst http:// ...

  8. e2e 自动化集成测试 环境搭建 Node.js Selenium WebDriverIO Mocha Node-Inspector

    Node.js已经出来了许多年载,至今才开始接触.周未在家闲来无事,一时心血来潮,Google了大量的文章,经过实验,终于可以把整个环境给搭起来, 废话不多话,请看步骤. 特别注意, 本文章是针对Wi ...

  9. BZOJ 1079 [SCOI2008]着色方案

    http://www.lydsy.com/JudgeOnline/problem.php?id=1079 思路:如果把每种油漆看成一种状态,O(5^15)不行 DP[a][b][c][d][e][f] ...

  10. LightOJ 1422 Halloween Costumes

    dp[i]][j]=min(dp[i+1][j]+1,dp[i+1][k-1]+dp[k][j]) 表示第i天到j的最小数量.如果第i天的衣服只自己穿的话,不考虑后面的就是dp[i][j]=dp[i+ ...