当前位置: 首页 > news >正文

网络推广网站培训班爱网站查询挖掘工具

网络推广网站培训班,爱网站查询挖掘工具,视频网站界面设计,上海方正大厦网站建设题目 有 N N N 个元素,编号 1 , 2.. N 1,2..N 1,2..N,每一对元素之间的大小关系是确定的,关系具有反对称性,但不具有传递性。 注意:不存在两个元素大小相等的情况。 也就是说,元素的大小关系是 N N N…

题目

N N N 个元素,编号 1 , 2.. N 1,2..N 1,2..N,每一对元素之间的大小关系是确定的,关系具有反对称性,但不具有传递性。

注意:不存在两个元素大小相等的情况。

也就是说,元素的大小关系是 N N N 个点与 N ∗ ( N − 1 ) / 2 N*(N−1)/2 N(N1)/2 条有向边构成的任意有向图。

然而,这是一道交互式试题,这些关系不能一次性得知,你必须通过不超过 10000 次提问来获取信息,每次提问只能了解某两个元素之间的关系。

现在请你把这 N N N 个元素排成一行,使得每个元素都小于右边与它相邻的元素。

你可以通过我们预设的 bool 函数 compare 来获得两个元素之间的大小关系。

例如,编号为 a a a b b b 的两个元素,如果元素 a a a 小于元素 b b b,则 compare(a,b) 返回 true,否则返回 false

N N N 个元素排好序后,把他们的编号以数组的形式输出,如果答案不唯一,则输出任意一个均可。

数据范围

1 ≤ N ≤ 1000 1≤N≤1000 1N1000

输入样例

[[0, 1, 0], [0, 0, 0], [1, 1, 0]]

输出样例

[3, 1, 2]

分析

根据数学归纳法,假设前 k − 1 k-1 k1 个元素已经按要求排成一行,如果能确定第 k k k 个元素应该放在哪一个前面,即可解决此问题。

可以通过这样一种二分法确定第 k k k 个元素的位置:若第 k k k 个元素比第 m i d mid mid 个元素小,令 r = m i d r = mid r=mid,否则令 l = m i d + 1 l = mid + 1 l=mid+1。二分的初始区间可设为 [ 1 , k ] [1,k] [1,k],区间中的 k k k 这个值表示放在所有 k − 1 k-1 k1 个元素之后。

可以证明二分一定可以找到一个合法的位置插入,证明如下。

  1. 如果第 k k k 个元素比第 m i d mid mid 个元素小。
    继续比较 k k k m i d − 1 mid-1 mid1 这两个元素,若第 k k k 个元素比第 m i d − 1 mid - 1 mid1 个元素大,则 k k k 可以插在 m i d − 1 mid - 1 mid1 m i d mid mid 之间;否则说明元素 k k k 比元素 m i d − 1 mid - 1 mid1 小,那就再比较 k k k m i d − 2 mid - 2 mid2 这两个元素,依此类推,直到发现第 k k k 个元素比第 1 个元素小,那就放在最前边。
  2. 如果第 k k k 个元素比第 m i d mid mid 个元素大,同理。

以上只是一个证明,当然不会真的去依次比较 k k k 与每个元素。实际上通过二分,每询问一次 ( k k k m i d mid mid),就可以把区间 [ l , r ] [l,r] [l,r] 缩小一半,因此至多 l o g k logk logk 次询问就可以确定 k k k 应该放在哪里。把 N N N 个元素排成一行的总询问次数不超过 N l o g N NlogN NlogN

代码

// Forward declaration of compare API.
// bool compare(int a, int b);
// return bool means whether a is less than b.class Solution {
private:vector<int> arr;//第一个比arr[k]大的数的位置int binarySearch(int k) {int left = 0;int right = k;while (left < right) {int mid = (left + right) >> 1;if (compare(arr[k], arr[mid])) { //arr[k] < arr[mid]right = mid;} else {left = mid + 1;}}return left;}
public:vector<int> specialSort(int N) {for (int i = 0; i < N; i++) {arr.emplace_back(i + 1);}for (int k = 0; k < N; k++) {int cur = arr[k];int pos = binarySearch(k); //arr[k]应该放到pos位置for (int j = k - 1; j >= pos; j--) { //pos到k-1位置的数全部向后移动一个位置arr[j + 1] = arr[j];}arr[pos] = cur;}return arr;}
};
http://www.mmbaike.com/news/28748.html

相关文章:

  • wordpress标签并集显示想做seo哪里有培训的
  • 做网站淄博电脑培训网上课程
  • 排名前十的网站怎么做公司网站推广
  • qq电脑版搜索引擎优化宝典
  • 智能手机网站模板阿里巴巴国际贸易网站
  • wordpress制作官方网站腾讯广点通广告投放平台
  • 门户网站制作价格表手机网站关键词seo
  • 深圳网站建设与推广网络推广公司加盟
  • b2b公司关键词排名优化品牌
  • 门户型网站模板it培训班大概需要多少钱
  • 网站建设客户需求分析表郑州网站推广优化公司
  • 网页制作的价格怎么去优化关键词
  • 网站图片翻页怎么做免费seo网站推荐一下
  • 吉林电商网站建设公司哪家好百度网盘登陆入口
  • wordpress一数据库多网站18款禁用网站app直播
  • 做窗帘店的网站seo短视频保密路线
  • 郑州做网站大量网站被关西安竞价托管公司
  • 衡水企业网站建设报价广告公司职位
  • 秦皇岛做网站seo的百度一下进入首页
  • 在线logo制作生成免费网站上海aso优化公司
  • 做音乐网站没有版权长春网站建设方案优化
  • 为啥要用java做网站php个人网站模板
  • 松江网站制作电脑培训班一般多少钱
  • 软件编程基础知识福州seo推广公司
  • 如何制作一个个人网页福州百度快速优化排名
  • 做网站 毕业设计广州做seo的公司
  • 网站服务器不稳定今日国内新闻大事20条
  • 品牌营销型网站建设百度客服人工电话多少
  • 临沂做网站公司制作公司网页多少钱
  • asp动态网站开发基...西安seo网站排名