求第k大的数(用到快速排序算法的思想)
//下面两种part效率比较:相同运算量下part比part2快5倍左右,part2写法简单但是效率低 #include "stdafx.h"
#include <iostream>
#include <stdio.h>
using namespace std; int part(int *arr, int l , int r)
{
c_num += r - l;
swap(arr[r],arr[l+rand()%(r-l)]);
int q = r--;
while( l < r)
{
while(l <= r && arr[l] <= arr[q]) ++l;
while(l < r && arr[r] >= arr[q]) --r;
if(l<r&&arr[l]>arr[r]) swap(arr[l], arr[r]);
}
if(l<q&&arr[l]>arr[q]) swap(arr[l], arr[q]);
return l;
} int part2(int *arr, int l , int r)
{
c_num += r - l;
int k, q = l;
swap(arr[l], arr[l+rand()%(r-l)]);
for(k = l+; k <= r; ++k)
{
if(arr[k] <= arr[q])
{
if(++l != k)
swap(arr[l], arr[k]);
}
}
swap(arr[l], arr[q]);
return l;
} void qsort(int *arr, int l, int r)
{
if(l >= r) return;
int mid = part(arr, l , r);
qsort(arr, l, mid-);
qsort(arr,mid+, r);
} int findNumK(int *arr, int l, int r, const int k)
{
if(l >= r)
{
return arr[k];
}
int mid = part(arr, l , r);
if(k < mid)
{
return findNumK(arr, l, mid-, k);
}
else if (k > mid)
{
return findNumK(arr,mid+, r, k);
}
else
{
return arr[k];
}
}
#define MAX_RAND 82934829
int myRand(int n)
{
return (long((double)rand()/RAND_MAX * MAX_RAND))%n;
}
const int n = ;
int ki = ;
int arr[n];
int brr[n];
int _tmain(int argc, _TCHAR* argv[])
{
for(int i = ; i < n; ++i)
{
arr[i] = i;
}
for(int i = ; i < n; ++i)
{
swap(arr[i],arr[myRand(n)]);
}
for(int i = ; i < n; ++i)
{
brr[i] = arr[i];
}
printf("@@@@@@@\n");
while(cin>>ki)
{
printf("\n%d %d\n", c_num, findNumK(brr, , n-, n-ki));
for(int i = ; i < n; ++i)
{
brr[i] = arr[i];
}
c_num = ;
}
printf("\n################\n");
c_num = ;
qsort(arr, , n-);
for(int i = n-; i >= n - ki; --i)
{
printf("%d ", arr[i]);
}
printf("\n%d\n",c_num);
getchar();
return ;
}
求第k大的数(用到快速排序算法的思想)的更多相关文章
- 《数据结构与算法分析:C语言描述》读书笔记------练习1.1 求第K大的数
求一组N个数中的第k个最大者,设k=N/2. import java.util.Random; public class K_Max { /** * @param args */ //求第K大的数,保 ...
- 无序数组求第K大的数
问题描述 无序数组求第K大的数,其中K从1开始算. 例如:[0,3,1,8,5,2]这个数组,第2大的数是5 OJ可参考:LeetCode_0215_KthLargestElementInAnArra ...
- POJ 2985 The k-th Largest Group(树状数组 并查集/查找第k大的数)
传送门 The k-th Largest Group Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 8690 Acce ...
- 寻找数列中第k大的数算法分析
问题描述:给定一系列数{a1,a2,...,an},这些数无序的,现在求第k大的数. 看到这个问题,首先想到的是先排序,然后直接输出第k大的数,于是得到啦基于排序的算法 算法一: #include&l ...
- [LeetCode] 4. Median of Two Sorted Arrays(想法题/求第k小的数)
传送门 Description There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the m ...
- 求第k小的数
题目链接:第k个数 题意:求n个数中第k小的数 题解: //由快速排序算法演变而来的快速选择算法 #include<iostream> using namespace std; const ...
- 给定两个数组,这两个数组是排序好的,让你求这两个数组合到一起之后第K大的数。
题目:给定两个数组,这两个数组是排序好的,让你求这两个数组合到一起之后第K大的数. 解题思路: 首先取得数组a的中位数a[aMid],然后在b中二分查找a[aMid],得到b[bMid],b[bSt] ...
- 求数列中第K大的数
原创 利用到快速排序的思想,快速排序思想:https://www.cnblogs.com/chiweiming/p/9188984.html array代表存放数列的数组,K代表第K大的数,mid代表 ...
- 无序数组求第k大/第k小的数
根据http://www.cnblogs.com/zhjp11/archive/2010/02/26/1674227.html 博客中所总结的7种解法,我挑了其中的解法3和解法6进行了实现. 解法3: ...
随机推荐
- Linux学习总结(9)——Linux 新手必知必会的 10 条 Linux 基本命令
Linux 对我们的生活产生了巨大的冲击.至少你的安卓手机使用的就是 Linux 核心.尽管如此,在第一次开始使用 Linux 时你还是会感到难以下手.因为在 Linux 中,通常需要使用终端命令来取 ...
- 金融项目java开发_BigDecimal(解决计算精度问题)
当使用double进行商业运算时,double计算会丢失精度.可以使用BigDecimal进行计算. import java.math.BigDecimal; import org.junit.Tes ...
- 解决Python 插查 MySQL 时中文乱码问题
首先找到这里的解决方法, count = cursor.fetchall() for i in count: idc_a = i[0] if isinstance(idc_a, unicode): i ...
- vim使用(二):经常使用功能
1. vim经常使用功能 vim的经常使用功能.包含块的选择.复制,多文件的编辑.多窗体等功能. 2. vim块选择 块选择是将文档中的一块能够选择复制,粘贴,不用整行的处理. 按下 v , V . ...
- 基于express+redis高速实现实时在线用户数统计
作者:zhanhailiang 日期:2014-11-09 本文将介绍怎样基于express+redis高速实现实时在线用户数统计. 1. 在github.com上创建项目uv-tj.将其同步到本地: ...
- 轻松学习之Linux教程四 神器vi程序编辑器攻略
本系列文章由@超人爱因斯坦出品,转载请注明出处. 文章链接: http://hpw123.net/a/Linux/Linuxjichu/2014/1026/93. ...
- vue23:vue-loader
vue-loader: 其他loader -> css-loader.url-loader.html-loader..... 后台: nodeJs(模块化) -> require expo ...
- Ehcache整合spring配置,配置springMVC缓存
为了提高系统的运行效率,引入缓存机制,减少数据库访问和磁盘IO.下面说明一下ehcache和spring整合配置. 1. 需要的jar包 slf4j-api-1.6.1.jar ehcache-c ...
- BZOJ 3224 平衡树模板题
Treap: //By SiriusRen #include <cstdio> #include <algorithm> using namespace std; int n, ...
- 基于Java的开源3D游戏引擎jMonkeyEngine
jMonkeyEngine简介 jMonkeyEngine是一款纯Java语言编写的游戏引擎,继承了Java应用跨平台的特性,而且是开放源代码的,遵循BSD开源协议,BSD开源协议用一句简单的话概括就 ...