编程之美2.5:寻找最大的K个数
编程之美2.5:寻找最大的K个数
引申:寻找第k大的数:
方法一:
// 选择第k大的数(通过改进快速排序来实现)
public static void SelectShort(int[] array, int low, int high, int k, out int value)
{
int i = low;
int j = high;
int tempItem = array[low];
value = int.MinValue; while (low < high)
{
while (array[high] > tempItem
&& high > low)
{
high--;
} if (low < high)
{
array[low] = array[high];
low++; while (array[low] <= tempItem
&& low < high)
{
low++;
} array[high] = array[low];
high--;
}
} array[low] = tempItem; if (low == array.Length - k)
{
value = array[low];
return;
}
else if (low < array.Length -k) // 第k个元素在右分支中
{
if (low + < j)
{
SelectShort(array, low + , j, k, out value);
}
}
else // (low > k-1)第k个元素在左分支中
{
if (i < low - )
{
SelectShort(array, i, low - ,k,out value);
}
}
}
方法二:
借助编程之美的思想,求前k个最大的数,其中最小的就是。
// 创建最大堆
public static void CreateStack(int[] array, int startIndex, int lastIndex)
{
for (int root = lastIndex / ; root >= startIndex; root--)
{
int currentRoot = root;
int leftLeafIndex = * root + ; // 左孩子
int rightLeafIndex = leftLeafIndex +; // 右孩子 while (leftLeafIndex <= lastIndex)
{
if (leftLeafIndex < lastIndex
&& rightLeafIndex <= lastIndex
&& array[leftLeafIndex] < array[rightLeafIndex])// 右孩子存在而且右孩子大于左孩子
{
leftLeafIndex++;
} if (array[leftLeafIndex] > array[root])
{
int temp = array[root];
array[root] = array[leftLeafIndex];
array[leftLeafIndex] = temp; currentRoot = * currentRoot + ; //继续寻找是否到了叶子结点
leftLeafIndex = * currentRoot + ;
}
else
{
break;
}
}
}
} //堆排序
public static void StackSort(int[] arrary)
{
CreateStack(arrary, , arrary.Length - ); int temp; for (int j = arrary.Length - ; j > ; j--)
{
temp = arrary[j];
arrary[j] = arrary[];
arrary[] = temp; CreateStack(arrary, , j - );
}
}
编程之美2.5:寻找最大的K个数的更多相关文章
- 2017“编程之美”终章:AI之战勇者为王
编者按:8月15日,第六届微软“编程之美”挑战赛在选手的火热比拼中圆满落下帷幕.“编程之美”挑战赛是由微软主办,面向高校学生开展的大型编程比赛.自2012年起,微软每年都在革新比赛命题.紧跟时代潮流, ...
- 编程之美2014挑战赛 复赛 Codehunt平台试题答案
var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...
- LeetCode:Climbing Stairs(编程之美2.9-斐波那契数列)
题目链接 You are climbing a stair case. It takes n steps to reach to the top. Each time you can either c ...
- 24点C++程序实现 编程之美1.16
解法1,对于任意输入的四个数字,给出一个24点的解法,若无解,则没有输出. 原理参照下图(编程之美原书) 代码如下,仅供参考 // 1.16.cpp : Defines the entry point ...
- Python编程之美:最佳实践指南PDF高清完整版免费下载|百度云盘|Python新手到进阶
百度云盘:Python编程之美:最佳实践指南PDF高清完整版免费下载 提取码:1py6 内容简介 <Python编程之美:最佳实践指南>是Python用户的一本百科式学习指南,由Pytho ...
- 寻找最大的k个数问题
这是编程之美书第2.5节的一道题目. 各种解法: 解法一,用nlgn复杂度的排序算法对数组进行从大到小排序,取前K个.但这方法做了两件不必要做的事:它对想得到的K个数进行了排序,对不想得到的n-K个数 ...
- 算法系列:寻找最大的 K 个数
Copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...
- 算法练习:寻找最小的k个数
参考July的文章:http://blog.csdn.net/v_JULY_v/article/details/6370650 寻找最小的k个数题目描述:查找最小的k个元素题目:输入n个整数,输出其中 ...
- 第2章 数字之魅——寻找最大的K个数
寻找最大的K个数 问题描述 在面试中,有下面的问答: 问:有很多个无序的数,我们姑且假定它们各不相等,怎么选出其中最大的若干个数呢? 答:可以这样写:int array[100] …… 问:好,如果有 ...
随机推荐
- Java JDK的安装以及环境变量的配置
安装并配置完Android SDK之后,本想着可以做个简单的APP应用了,只是依然提示我“请确认Java JDK是否安装”类似的报错,于是又进行了Java JDK的安装以及环境变量的配置. 1.下载地 ...
- 【转】Session ID/session token 及和cookie区别
Session + Cookie 知识收集! cookie机制采用的是在客户端保持状态的方案.它是在用户端的会话状态的存贮机制,他需要用户打开客户端的cookie支持.cookie的作用就是为了解决 ...
- 算法--数组中出现一次的数,其余都出现N次
转载:http://blog.csdn.net/morewindows/article/details/12684497 题目:数组A中,除了某一个数字x之外,其他数字都出现了三次,而x出现了一次.请 ...
- JDE910笔记1--基础介绍及配置
1.一般JDE部署后环境: DV:开发环境 PY:测试环境 PD:正式环境 根据端口号区分不同环境,可配置.同时,JDE默认使用分发服务器,不同环境连接为不同的数据库. 2.命名规范: 自定义项目.函 ...
- string字符串类型
一次设置一个key-value 使用set命令可以一次设置一个key-value,使用get命令可以查询key所关联的字符串值.如下图所示. 一次设置多个key-value 使用mset命令可以设置多 ...
- sdut 2605 A^X mod P
http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2605 这个题卡的是优化,直观解法是在求x^y时 ...
- POJ 2886 Who Gets the Most Candies?
思路: 对于 k 位置的 孩子,他的 数字是 +num 那么因为他自己本身是要被踢走的,所以相对位置 为k= k+num-1 如果数字是 -num,那么按正着数就没影响,k=k-num.线段树存储当前 ...
- 一模 (2) day1
第一题: 题目大意: 设 2n 张牌分别标记为 1, 2, ..., n, n+1, ..., 2n,初始时这 2n 张牌按其标号从小到大排列.经一次洗牌后,原来的排列顺序变成 n+1, 1, n+2 ...
- Servlet、MySQL中文乱码
1.Servlet中文乱码: 在doPost或doGet方法里,加上以下两行即可: response.setContentType("text/html;charset=UTF-8" ...
- 创建单例的DbContext
/// <summary> /// 说明: /// 创建日期:2016/9/30 14:49:48 /// 创建人:曹永承 /// </summary> public clas ...