热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

golang算法计算10000个数里最小的10个数

<svg


前言

从包含M个数字的池子里,取出前k个(最小的)数字。

分析

使用mapreduce思想,将M个数字的池,拆成容量为vol的子池,对子池取出最小的10个数,将所有子池的最小十个数合并,再取一下最小10个数。

  • 生成M个数字的大数组
func GenMNumberArr(M int, seed time.Time) []int {
var rs = make([]int, 0, M)
rand.Seed(seed.UnixNano())
for i := 0; i < M; i {
rs = append(rs, rand.Intn(1029381))
}
return rs
}
// 生成了长度20的随机数组
// 输出[...], 20
func TestGenMNumberArr(t *testing.T) {
rs := GenMNumberArr(20, time.Now())
fmt.Println(len(rs))
fmt.Println(rs)
}

  • 子池拆分
func SplitArr(arr []int, vol int) [][]int {
var rs = make([][]int, 0, 100)
var tmp []int
L:
for i, _ := range arr {
if (i 1)%vol == 0 {
tmp = arr[0 : i 1]
rs = append(rs, tmp)
arr = arr[i 1:]
goto L
} else {
if i == len(arr)-1 {
rs = append(rs, arr)
}
continue
}
}
return rs
}
// 输出 [[1 24 1 2 3] [4 11 12 19 11] [17 19 22 23]]
func TestSplitArr(t *testing.T) {
rs := SplitArr([]int{1, 24, 1, 2, 3, 4, 11, 12, 19, 11, 17, 19, 22, 23}, 5)
fmt.Println(rs)
}

  • 对包含大于等于K个数字的数组,进行取最小的十个数字的操作
// 从数组中,选出最小的K个数据,并升序排列成数组
func GetMinK(k int, src []int) []int {
if k > len(src) {
panic(fmt.Errorf("min k must smaller than src length, but got k '%d', src.len '%d'", k, len(src)))
}
var tmp int
for i := 0; i < k; i {
for j := i 1; j < len(src); j {
if src[i] > src[j] {
tmp = src[i]
src[i] = src[j]
src[j] = tmp
}
}
}
return src[:k]
}
// 从数组中,选取了最小的4个
// 输出 [1 2 3 3]
func TestGetMinK(t *testing.T) {
rs := GetMinK(4, []int{1, 3, 4, 5, 6, 12, 3, 2, 15, 199})
fmt.Println(rs)
}

  • 最后,从10000个数中,取最小的10个数
func TestGetMin10NumberFrom10000(t *testing.T) {
arr10000 := GenMNumberArr(10000, time.Now())
subArrs := SplitArr(arr10000, 100)
minArr := make([]int, 0, 100)
for i, _ := range subArrs {
minArr = append(minArr, GetMinK(10, subArrs[i])...)
}
rs :=GetMinK(10, minArr)
fmt.Println(rs)
}

实现仓库

点这里


推荐阅读
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 简述在某个项目中需要分析PHP代码,分离出对应的函数调用(以及源代码对应的位置)。虽然这使用正则也可以实现,但无论从效率还是代码复杂度方面考虑ÿ ... [详细]
  • 可空类型可空类型主要用于参数类型声明和函数返回值声明。主要的两种形式如下: ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • PHP引用的概念和用法详解
    本文详细介绍了PHP中引用的概念和用法。引用是指不同的变量名访问同一个变量内容,类似于Unix文件系统中的hardlink。文章从引用的定义、作用、语法和注意事项等方面进行了解释和示例。同时还介绍了对未定义变量使用引用的情况,以及在函数和new运算符中使用引用的注意事项。 ... [详细]
  • 工作经验谈之-让百度地图API调用数据库内容 及详解
    这段时间,所在项目中要用到的一个模块,就是让数据库中的内容在百度地图上展现出来,如经纬度。主要实现以下几点功能:1.读取数据库中的经纬度值在百度上标注出来。2.点击标注弹出对应信息。3 ... [详细]
  • 获取时间的函数js代码,js获取时区代码
    本文目录一览:1、js获取服务器时间(动态)2 ... [详细]
  • 语义分割系列3SegNet(pytorch实现)
    SegNet手稿最早是在2015年12月投出,和FCN属于同时期作品。稍晚于FCN,既然属于后来者,又是与FCN同属于语义分割网络 ... [详细]
  • python3下载mapbox矢量切片通过观察mapbox的页面开发者工具里的network可以发现,打开矢量切片和字体切片pbf和prite图标的链接, ... [详细]
  • 开发笔记:线性回归读取txt
    txt中部分数据如下:1.0000000.067732 ... [详细]
  • 湍流|低频_youcans 的 OpenCV 例程 200 篇106. 退化图像的逆滤波
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了youcans的OpenCV例程200篇106.退化图像的逆滤波相关的知识,希望对你有一定的参考价值。 ... [详细]
author-avatar
于华521_811
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有