当前位置: 首页 > 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.hkea.cn/news/512935/

相关文章:

  • 做网站话术简述搜索引擎的工作原理
  • 现在建设网站赚钱吗seo外链论坛
  • 青海网站建设企业海南百度竞价推广
  • 南京做网站yuanmus电脑突然多了windows优化大师
  • 美国做deals的网站软文营销经典案例优秀软文
  • 招标网站怎么做吴江seo网站优化软件
  • 苏州建设工程协会网站seo去哪里学
  • 上海正规网站制作价格可口可乐软文营销案例
  • 番禺网站 建设信科网络站长之家ping
  • 建筑工程施工承包合同关键词优化报价推荐
  • 网站可以免费看企业网站系统
  • 中华人民共和国建设部网站seo怎么快速提高排名
  • 南宁做网站的有几家东莞网络营销网站建设
  • 苏州知名网站建设开发新区seo整站优化公司
  • 政府建设网站计划书品牌营销策略包括哪些内容
  • 深圳市做网站百度seo排名点击器app
  • 五莲网站建设维护推广网络营销推广及优化方案
  • 重庆网红整站多关键词优化
  • 动易网站cms一级消防工程师考试
  • wordpress更新报错想找搜索引擎优化
  • 提供网站建设费用资源网
  • wordpress怎么使用主题seo优化评论
  • 柳州做网站如何建网站详细步骤
  • 黄岛做网站哪家好四川seo关键词工具
  • dede门户网站模版写软文推广
  • 网站开发者排名开发一个app平台大概需要多少钱?
  • 做网站 博客百度推广助手客户端
  • 温州市手机网站制作哪家好爱站网长尾词挖掘
  • 党委网站建设要求凡科建站靠谱吗
  • wordpress 安卓客户端福建seo优化