返回顶部
首页 > 资讯 > 精选 >GO语言中常见的排序算法怎么使用
  • 342
分享到

GO语言中常见的排序算法怎么使用

2023-06-30 00:06:30 342人浏览 安东尼
摘要

今天小编给大家分享一下Go语言中常见的排序算法怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。快排package&nb

今天小编给大家分享一下Go语言中常见的排序算法怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

快排

package mainimport ("fmt""math/rand""time")func main() {li:=[]int{1,3,5,2,4,6,9,7}left:=0right:=len(li)-1fmt.Println(quick_sort(li,left,right))}func quick_sort(li []int, left,right int) []int {if left<right{mid := paitition(li,left,right)quick_sort(li,left,mid-1)quick_sort(li,mid+1,right)}return li}func paitition(li []int, left,right int) int {r := rand.New(rand.NewSource(time.Now().UnixNano()))res := r.Intn(right-left+1)+leftli[left],li[res] = li[res],li[left]temp:=li[left]for left<right {for left<right && li[right]>=temp{right-=1}li[left]=li[right]for left<right && li[left]<=temp{left+=1}li[right]=li[left]}li[left]=tempreturn left}

冒泡

package mainimport "fmt"func main()  {li:=[]int{1,3,5,2,4,6,9,7}fmt.Println(bubble_sort(li))}func bubble_sort(li[]int) []int {for i:=0;i<len(li)-1;i++ {res:=truefor j:=0;j<len(li)-1-i;j++{if li[j]>li[j+1]{li[j],li[j+1]=li[j+1],li[j]res=false}}if res{return li}}return nil}

选择排序

package mainimport "fmt"func main()  {li:=[]int{1,3,5,2,4,6,9,7}fmt.Println(select_sort(li))}func select_sort(li[]int) []int {for i:=0;i<len(li);i++ {min_loc := ifor j:=i+1;j<len(li);j++ {if li[j]<li[min_loc] {min_loc=j}}if min_loc!=i {li[i],li[min_loc]=li[min_loc],li[i]}}return li}

插入排序

package mainimport "fmt"func main()  {li:=[]int{1,3,201,5,2,100,4,6,9,7,2}fmt.Println(insert_sort(li))}func insert_sort(li[]int) []int {for i:=1;i<len(li); i++{tmp:=li[i]j := i-1for j>0 && li[j]>tmp {li[j+1]=li[j]j=j-1}li[j+1] = tmp}return li}

希尔排序

package mainimport "fmt"func main()  {li:=[]int{1,3,201,5,2,100,4,6,9,7,2}fmt.Println(shell_sort(li))}func shell_sort(li[]int) []int {res := len(li)/2for res>0 {for i:=res;i<len(li);i++{tmp := li[i]j := i-resfor j>=0 && tmp <li[j]{li[j+res] = li[j]j -= res}li[j+res] = tmp}res /=2  //res = res/2}return li}

二分法查找

package mainimport "fmt"func main()  {li:=[]int{1,2,3,4,5,6,7,8}left:=0right:=len(li)-1value := 8fmt.Println(bin_search(li,value,left,right))}func bin_search(li[]int,value,left,right int) int {if left <=right{mid := (left+right)/2if li[mid] == value{return mid} else if li[mid]>value {return bin_search(li,value,left,mid-1)} else {return bin_search(li,value,mid+1,right)}} else {return 999}}

以上就是“GO语言中常见的排序算法怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

--结束END--

本文标题: GO语言中常见的排序算法怎么使用

本文链接: https://lsjlt.com/news/326856.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • GO语言中常见的排序算法怎么使用
    今天小编给大家分享一下GO语言中常见的排序算法怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。快排package&nb...
    99+
    2023-06-30
  • GO语言中常见的排序算法使用示例
    目录快排冒泡选择排序插入排序希尔排序二分法查找快排 package main import ( "fmt" "math/rand" "time" ) func main() {...
    99+
    2024-04-02
  • C语言常见排序算法归并排序
    目录前言 一、归并排序1.1 基本思想1.2 算法思想1.3 程序设计思想1.4 程序实现1.5 归并排序的特性总结前言 本期为大家带来的是常见排序算法中的归并排序,博主在...
    99+
    2024-04-02
  • Java中常见的查找算法与排序算法怎么使用
    这篇文章主要介绍了Java中常见的查找算法与排序算法怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java中常见的查找算法与排序算法怎么使用文章都会有所收获,下面我们一起来看看吧。1. 基本查找也叫做顺...
    99+
    2023-07-05
  • C语言常见排序算法之交换排序(冒泡排序,快速排序)
    目录前言1.交换排序——冒泡排序1.1 算法思想1.2 动图演示1.3 冒泡最好的情况 2. 交换排序——快速排序...
    99+
    2024-04-02
  • C语言中排序算法怎么用
    这篇文章主要为大家展示了“C语言中排序算法怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中排序算法怎么用”这篇文章吧。排序的概念及其运用排序的概念排序:所谓排序,就是使一串记录,按照...
    99+
    2023-06-29
  • Go语言实现常用排序算法的示例代码
    目录冒泡排序快速排序选择排序插入排序排序算法是在生活中随处可见,也是算法基础,因为其实现代码较短,应用较常见。所以在面试中经常会问到排序算法及其相关的问题,可以说是每个程序员都必须得...
    99+
    2024-04-02
  • C语言常见排序算法之插入排序(直接插入排序,希尔排序)
    目录前言一、直接插入排序1.1 基本思想1.2 算法思想1.3 程序实现1.4 直接插入排序的总结二、希尔排序2.1 算法思想2.2 程序实现2.3 希尔排序的特征总结前言...
    99+
    2024-04-02
  • c语言快速排序算法怎么使用
    使用快速排序算法,需要先定义一个快速排序函数,然后在主函数中调用该函数。下面是一个示例的C语言快速排序算法的实现:```c#incl...
    99+
    2023-09-21
    c语言
  • Java常见排序算法怎么实现
    本文小编为大家详细介绍“Java常见排序算法怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java常见排序算法怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。汇总:1. 冒泡排序每轮循环确定最值;...
    99+
    2023-06-29
  • Golang怎么实现常见排序算法
    这篇文章主要介绍“Golang怎么实现常见排序算法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang怎么实现常见排序算法”文章能帮助大家解决问题。五种基础排序算法对比五种基础排序算法对比1、...
    99+
    2023-06-30
  • 介绍java中的常见排序算法
    Java中的排序算法主要包括以下几种: 冒泡排序(Bubble Sort)选择排序(Selection Sort)插入排序(Insertion Sort)快速排序(Quick Sort)归并排序(Merge Sort)堆排序(Heap So...
    99+
    2023-10-26
    算法 排序算法 数据结构 java 笔记 学习
  • c语言实现的几种常用排序算法
    概述 最近重新回顾了一下数据结构和算法的一些基本知识,对几种排序算法有了更多的理解,也趁此机会通过博客做一个总结。 1.选择排序-简单选择排序 选择排序是最简单的一种基于O(n2)时...
    99+
    2024-04-02
  • 浅谈Java常见的排序算法
    目录一、直接插入排序二、希尔排序三、冒泡排序四、快速排序五、选择排序(Selection Sort)六、堆排序七、归并排序一、直接插入排序 基本思想: 将一个记录插入到已排序的有序表...
    99+
    2024-04-02
  • 优化常见的java排序算法
    目录冒泡排序原始的写法优化一优化二选择排序方法一方法二堆排序建大堆来实现堆排建小堆来实现堆排插入排序实现优化一优化二归并排序递归实现归并排序优化来看O(n)的排序当然除了基于比较的排...
    99+
    2024-04-02
  • java中几种常见的排序算法是什么
    java中几种常见的排序算法是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1 排序       排序,就是使一串记录,按照其中某个...
    99+
    2023-06-29
  • go语言运算符优先级怎么排序
    在Go语言中,运算符按照优先级从高到低的顺序进行计算。常见的运算符的优先级顺序:1、括号:()(最高优先级,用于强制改变运算顺序);2、单目运算符;3、乘性运算符;4、加性运算符;5、移位运算符;6、按位运算符;7、比较运算符;8、逻辑运算...
    99+
    2023-12-21
    go语言 运算符
  • Java中常见的查找算法与排序算法总结
    目录1. 基本查找2. 二分查找3. 插值查找4. 斐波那契查找5. 分块查找6. 哈希查找7. 树表查找十大排序算法1. 冒泡排序2. 选择排序3. 插入排序4. 快速排序数据结构...
    99+
    2023-03-11
    Java查找算法 Java排序算法 Java查找 排序
  • java中几种常见的排序算法总结
    目录本节目标;【插入排序】【优化版】【希尔排序】【选择排序】【堆排序】 【冒泡排序】介绍一个冒泡排序的优化方法; 【快速排序】【归并排序】【正文】【代码简介;】&...
    99+
    2024-04-02
  • 常见的php排序算法有哪些
    常见的PHP排序算法有以下几种:1. 冒泡排序(Bubble Sort):依次比较相邻的两个元素,将较大的元素向后移动,直到最后一个...
    99+
    2023-08-25
    php
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作