编程之美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] …… 问:好,如果有 ...
随机推荐
- 数据库索引<一> 索引结构表结构
有很长时间没有更新博客了,再过几天都2月分了,如果再不更新一篇,我1月分都没有更新,保持连续,今天更新一篇. 最近没有什么看技术方面的东西,游戏,画画搞这些去了.我发现我每年一到年底就是搞这些东西,其 ...
- oracle Redhat64 安装
详细可以参考:http://blog.csdn.net/chenfeng898/article/details/8782679 直接执行如下yum安装命令后,如果再出错,跳到2 yum -y inst ...
- 发送有序广播Ordered Broadcast
import android.os.Bundle;import android.app.Activity;import android.content.Intent;import android.vi ...
- Oracle练习题(1~19)
1. 查询Student表中的所有记录的Sname.Ssex和Class列. 2. 查询教师所有的单位即不重复的Depart列. 3. 查询Student表的所有记录. 4. 查询Score表中成绩在 ...
- hdu 4627 The Unsolvable Problem
http://acm.hdu.edu.cn/showproblem.php?pid=4627 分类讨论一下就可以 代码: #include<iostream> #include<cs ...
- load image
<img data-src="/path/to/image.jpg" alt="">img { opacity: 1; transition: op ...
- MongoDB Aggregate Methods(2) MonoDB 的 3 种聚合函数
aggregate(pipeline,options) 指定 group 的 keys, 通过操作符 $push/$addToSet/$sum 等实现简单的 reduce, 不支持函数/自定义变量 g ...
- Spring学习笔记之Bean的一些属性设置
1.beans 里边配置default-init-method="shunge",有这个方法的会执行,没有也不会报错 2.beans 里边配置default-destroy-met ...
- android之DOM生成与解析
DOM解析不适合于进行大数据文件的操作,DOM解析适合于对文件进行修改和随机存取的操作. DOM生成 //判断一下是否存在sdcard if(!Environment.getExternalStora ...
- Xceed WPF 主题皮肤控件Xceed Professional Themes for WPF详细介绍
Xceed Professional Themes for WPF是一款为你的整个应用程序提供完美WPF主题风格的控件,包含Office 2007和Windows 7,可以应用到任何微软官方的WPF控 ...