编程之美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个数的更多相关文章

  1. 2017“编程之美”终章:AI之战勇者为王

    编者按:8月15日,第六届微软“编程之美”挑战赛在选手的火热比拼中圆满落下帷幕.“编程之美”挑战赛是由微软主办,面向高校学生开展的大型编程比赛.自2012年起,微软每年都在革新比赛命题.紧跟时代潮流, ...

  2. 编程之美2014挑战赛 复赛 Codehunt平台试题答案

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  3. 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 ...

  4. 24点C++程序实现 编程之美1.16

    解法1,对于任意输入的四个数字,给出一个24点的解法,若无解,则没有输出. 原理参照下图(编程之美原书) 代码如下,仅供参考 // 1.16.cpp : Defines the entry point ...

  5. Python编程之美:最佳实践指南PDF高清完整版免费下载|百度云盘|Python新手到进阶

    百度云盘:Python编程之美:最佳实践指南PDF高清完整版免费下载 提取码:1py6 内容简介 <Python编程之美:最佳实践指南>是Python用户的一本百科式学习指南,由Pytho ...

  6. 寻找最大的k个数问题

    这是编程之美书第2.5节的一道题目. 各种解法: 解法一,用nlgn复杂度的排序算法对数组进行从大到小排序,取前K个.但这方法做了两件不必要做的事:它对想得到的K个数进行了排序,对不想得到的n-K个数 ...

  7. 算法系列:寻找最大的 K 个数

    Copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...

  8. 算法练习:寻找最小的k个数

    参考July的文章:http://blog.csdn.net/v_JULY_v/article/details/6370650 寻找最小的k个数题目描述:查找最小的k个元素题目:输入n个整数,输出其中 ...

  9. 第2章 数字之魅——寻找最大的K个数

    寻找最大的K个数 问题描述 在面试中,有下面的问答: 问:有很多个无序的数,我们姑且假定它们各不相等,怎么选出其中最大的若干个数呢? 答:可以这样写:int array[100] …… 问:好,如果有 ...

随机推荐

  1. C#获取相对路径的方法

    这八种C#获取相对路径的方法,包括获取和设置当前目录的完全限定路径.获取启动了应用程序的可执行文件的路径,不包括可执行文件的名称等等内容. C#获取相对路径1. 获取和设置当前目录的完全限定路径.   ...

  2. 【转】Nginx+php-fpm+MySQL分离部署详解

    转:http://www.linuxidc.com/Linux/2015-07/120580.htm Nginx+php-fpm+MySQL分离部署详解 [日期:2015-07-26] 来源:Linu ...

  3. css3内容溢出属性

    overflow是css2.0的属性,css3中新增了overflow-x和overflow-y属性. overflow-x主要是用来定义对水平方向内容溢出的剪切,而overflow-y主要是用来定义 ...

  4. thinkphp 调用系统的方法

    在需要调用的脚本 加载 load('filename');//filename为文件名

  5. HDU 5768 中国剩余定理

    题目链接:Lucky7 题意:求在l和r范围内,满足能被7整除,而且不满足任意一组,x mod p[i] = a[i]的数的个数. 思路:容斥定理+中国剩余定理+快速乘法. (奇+ 偶-) #incl ...

  6. sql 如何过滤重复记录

    distinct : select distinct ID from table1

  7. OL/SQL编程练习

    create or replace procedure pr_first is --一个变量 v_a ) := '总有一天我的生命将走到尽头'; --一个常量 c_b constant ) := '而 ...

  8. POJ 1062 昂贵的聘礼 最短路 难度:0

    http://poj.org/problem?id=1062 #include <iostream> #include <cstring> #include <queue ...

  9. C# SQLiteDataReader获得数据库指定字段的值

    获得数据库指定字段的值,赋给本地变量 (1)如下,获得userinfo数据表里的字段"userid"."orgid", string userid=" ...

  10. 使用ASP.Net WebAPI构建REST服务(四)——参数绑定

    默认绑定方式 WebAPI把参数分成了简单类型和复杂类型: 简单类型主要包括CLR的primitive types,(int.double.bool等),系统内置的几个strcut类型(TimeSpa ...