查看: 2538| 回复: 9
跳转到指定楼层
上一主题 下一主题
收起左侧

Microsoft : Find pivot

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
//Given a sorted array (ex. {1,2,3,4,5,6,7,8}). A random number from the array is taken and put the left side
//array to right side and left side array to right side.
//in the example; if 6 is randomly taken, the array will become like {7,8,6,1,2,3,4,5}

这题比较简单,程序写起来比较麻烦,考虑到相同值的情况

上一篇:Google : 两个排序数组中求第k大的sum(a+b)
下一篇:Google : Make a 5 number generator from a 3 number generator
🔗
Imbalism 2011-5-8 13:23:24 | 只看该作者
全局:
请问先将这个数列倒着排,然后再将pivot分开的两部分分别倒着排,可以吗?
回复

使用道具 举报

🔗
darksteel 2011-5-8 22:22:04 | 只看该作者
全局:
回复 2# Imbalism
应该没错!如果给出的pivot是下标的话,三个reverse就能搞定
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-9 12:50:31 | 只看该作者
全局:
回复  Imbalism
应该没错!如果给出的pivot是下标的话,三个reverse就能搞定
darksteel 发表于 2011-5-8 22:22



    看标题,是Find Pivot, 不是转回来,可能题目没说清楚
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-9 12:52:16 | 只看该作者
全局:
回复  Imbalism
应该没错!如果给出的pivot是下标的话,三个reverse就能搞定
darksteel 发表于 2011-5-8 22:22



    不过如果题目是这样的话这个解法也很好啊
回复

使用道具 举报

🔗
darksteel 2011-5-9 13:28:21 | 只看该作者
全局:
回复 4# wwwyhx
题目是略有点不清楚,是说给出原数组和新数组,让判断哪个元素是所选的pivot?
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-10 12:49:14 | 只看该作者
全局:
回复  wwwyhx
题目是略有点不清楚,是说给出原数组和新数组,让判断哪个元素是所选的pivot?
darksteel 发表于 2011-5-9 13:28



    没错
回复

使用道具 举报

🔗
darksteel 2011-5-10 13:30:15 | 只看该作者
全局:
回复 7# wwwyhx
其实给出移动过的数组就行。
结果应该是返回值吧?因为如果是位置可能有多种情况。
大概是这样:
  1. int FindPivot(int a[], int n)
  2. {
  3.         int i = 1;
  4.         if(n == 1)
  5.                 return a[0];
  6.         while(a[i] == a[i-1])
  7.                 i++;
  8.         if(i == n || a[i] < a[i-1])
  9.                 return a[i-1];
  10.         while(a[i] >= a[i-1])
  11.                 i++;
  12.         return a[i];
  13. }
复制代码
回复

使用道具 举报

🔗
 楼主| wwwyhx 2011-5-10 17:43:14 | 只看该作者
全局:
本帖最后由 wwwyhx 于 2011-5-10 17:44 编辑
回复  wwwyhx
其实给出移动过的数组就行。
结果应该是返回值吧?因为如果是位置可能有多种情况。
大概是这样:
darksteel 发表于 2011-5-10 13:30



    服你了.... 二分都懒得用
回复

使用道具 举报

🔗
darksteel 2011-5-11 23:25:58 | 只看该作者
全局:
回复 9# wwwyhx
好像真能用二分诶,不过边界条件比较多,想想就麻烦啊
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表