给定一个数列a1,a2,a3,...,an和m个三元组表示的查询,对于每个查询(i,j,k),输出ai,ai+1,...,aj的升序排列中第k个数。

#include <iostream>
using namespace std;
#define SIZE 20
#define M 3
typedef struct Elem {
	int i, j;
	int k;
} ELEM; /* 表示一个元素的三元组结构 */

int getMedian(int* arr, int low, int high) {
	int mid = low + ((high - low) >> 1);

	if (arr[mid] > arr[high]) {
		swap(arr[mid], arr[high]);
	}
	if (arr[low] > arr[high]) {
		swap(arr[low], arr[high]);
	}
	if (arr[mid] > arr[low]) {
		swap(arr[low], arr[mid]);
	}

	return arr[low];
}

int findThMin(int* arr, int low, int high, int k) {
	int pivot = getMedian(arr, low, high);

	int lowTmp = low;
	int highTmp = high;

	while (lowTmp < highTmp) {
		while (lowTmp < highTmp && arr[highTmp] > pivot) {
			highTmp--;
		}
		arr[lowTmp] = arr[highTmp];

		while (lowTmp < highTmp && arr[lowTmp] < pivot) {
			lowTmp++;
		}
		arr[highTmp] = arr[lowTmp];
	}

	arr[lowTmp] = pivot;

	if (k == lowTmp) {
		return arr[lowTmp];
	} else if (k < lowTmp) {
		return findThMin(arr, low, lowTmp - 1, k);
	} else {
		return findThMin(arr, lowTmp + 1, high, k);
	}
}

int* getSubArray(int* arr, int begin, int end) {
	int* tmp = new int[end - begin + 1];

	for (int i = 0, j = begin; j <= end; ++i, j++) {
		tmp[i] = arr[j];
	}
	return tmp;
}

int main() {
	Elem* elem = new Elem();
	elem->i = 4;
	elem->j = 9;
	elem->k = 3;

	Elem* elem2 = new Elem();
	elem2->i = 2;
	elem2->j = 8;
	elem2->k = 6;

	Elem* elem3 = new Elem();
	elem3->i = 1;
	elem3->j = 6;
	elem3->k = 5;

	Elem *elems[M] = { elem, elem2, elem3 };

	int* arr = new int[SIZE];
	srand(unsigned(time(0)));
	for (int i = 0; i < SIZE; i++) {
		arr[i] = rand() * RAND_MAX + rand();
	}

	for (int i = 0; i < M; ++i) {
//		cout << elems[i]->k << endl;
		//获取指定子数组
		int* tmp = getSubArray(arr, elems[i]->i - 1, elems[i]->j - 1);

		/*cout << "before data set:" << endl;
		 for (int k = 0; k <= elems[i]->j - elems[i]->i; ++k) {
		 cout << tmp[k] << endl;
		 }*/

		//在规定的数组内取得第几个最小的元素
		int data = findThMin(tmp, 0, elems[i]->j - elems[i]->i,
				elems[i]->k - 1);
		cout << elems[i]->k << " th min data:" << data << endl;

		cout << "after data set:" << endl;
		for (int k = 0; k <= elems[i]->j - elems[i]->i; ++k) {
			cout << tmp[k] << endl;
		}
	}

	return 0;
}

给定一个数列a1,a2,a3,...,an和m个三元组表示的查询,对于每个查询(i,j,k),输出ai,ai+1,...,aj的升序排列中第k个数。的更多相关文章

  1. //给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和

    //给定N个整数序列{A1,A2,A3...An},求函数f(i,j)=(k=i~j)Ak的求和 # include<stdio.h> void main() { ,sum1; ]={,- ...

  2. 如何生成a1,a2,a3,a4这样的变量名

    var num=6; function Girl(beautifulScore){ this.beautifulScore=beautifulScore; } var girls=[]; for (v ...

  3. 给出一列数a1,a2,a3....an,求它们的逆序对数,即有多少个有序对(i,j) 使得iaj,n高达10的6次方

    //归并排序 //#include<stdio.h> //#include<string.h> //#include<algorithm> //#include&l ...

  4. 已知一个序列A1.A2….An,给你一个整数K,找到满足所有Ai+Aj>=k的数对(i,j)的个数

    #include<bits/stdc++.h> using namespace std; #define ll long long #define maxn 100010 /* 已知一个序 ...

  5. Java笔试题:给定一个ReadOnlyClass的对象roc,能否把这个对象的age值改成30?

    在Java笔试面试中,经常会遇到代码题,今天我们就来看一则Java代码笔试题. 有如下代码: Class ReadOnlyClass { private Integer age=20; public ...

  6. 寻找数列中第k大的数算法分析

    问题描述:给定一系列数{a1,a2,...,an},这些数无序的,现在求第k大的数. 看到这个问题,首先想到的是先排序,然后直接输出第k大的数,于是得到啦基于排序的算法 算法一: #include&l ...

  7. 2018.3.12 Leecode习题 给定一个整数数列,找出其中和为特定值的那两个数。

    给定一个整数数列,找出其中和为特定值的那两个数. 你可以假设每个输入都只会有一种答案,同样的元素不能被重用. 示例: 给定 nums = [2, 7, 11, 15], target = 9; 因为 ...

  8. Gym 101064 D Black Hills golden jewels 【二分套二分/给定一个序列,从序列中任意取两个数形成一个和,两个数不可相同,要求求出第k小的组合】

    D. Black Hills golden jewels time limit per test 2 seconds memory limit per test 256 megabytes input ...

  9. E - 小晴天老师系列——我有一个数列!

    E - 小晴天老师系列——我有一个数列! Time Limit: 20000/10000MS (Java/Others)    Memory Limit: 128000/64000KB (Java/O ...

随机推荐

  1. 实验吧_貌似有点难(php代码审计)&头有点大

    二话不说先贴代码 <?php function GetIP(){ if(!empty($_SERVER["HTTP_CLIENT_IP"])) $cip = $_SERVER ...

  2. 【实验吧】CTF_Web_登录一下好吗?

    实验吧CTF---Web篇 1. 打开登录地址(http://ctf5.shiyanbar.com/web/wonderkun/web/index.html),发现为一个登录界面,第一想到的是查看源代 ...

  3. [NOIp 2011]Mayan游戏

    Description Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游戏 ...

  4. [AHOI 2005]COMMON 约数研究

    Description Input 只有一行一个整数 N(0 < N < 1000000). Output 只有一行输出,为整数M,即f(1)到f(N)的累加和. Sample Input ...

  5. [SCOI2008]配对

    题目描述 你有 n 个整数Ai和n 个整数Bi.你需要把它们配对,即每个Ai恰好对应一个Bp[i].要求所有配对的整数差的绝对值之和尽量小,但不允许两个相同的数配对.例如A={5,6,8},B={5, ...

  6. 洛谷mNOIP模拟赛Day2-星空

    题目背景 pdf题面和大样例链接:http://pan.baidu.com/s/1cawM7c 密码:xgxv 命运偷走如果只留下结果, 时间偷走初衷只留下了苦衷. 你来过,然后你走后,只留下星空. ...

  7. ●BZOJ 3796 Mushroom追妹纸

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3796 题解: 题意:    给出三个串 A,B,C    找出一个最长串 S,    使得 ...

  8. Uva 437 巴比伦塔 && UVA10003

    要求底面严格小于它下方立方体的长宽,求出最高情况,一块石头可以多次使用 用结构体记录一块石头的三种放置情况,按面积排序. dp[i] = max(dp[i],dp[j] + block[i].high ...

  9. 零开始:NetCore项目权限管理系统:基础框架搭建

    有兴趣的同学可以一起做 喜欢NetCore的朋友,欢迎加群QQ:86594082 源码地址:https://github.com/feiyit/SoaProJect 新建一个空的解决方案,建立对应的解 ...

  10. 备忘:MySQL中修改表中某列的数据类型、删除外键约束

    -- MySQL中修改表中某列的数据类型 ALTER TABLE [COLUMN] 表名 MODIFY 列名 列定义; -- 删除外键约束 SHOW CREATE TABLE 表名; -- 复制CON ...