Golang排序和查找使用方法介绍

目录
  • 排序的介绍
  • 交换式排序法
  • 二维数组的介绍
  • 二维数组的应用场景
  • 二维数组快速入门
  • 二维数组的使用

排序的介绍

排序是将一组数据,依指定的顺序进行排列的过程。

排序的分类:

1.内部排序:

指将需要处理的所有数据都加载到内部存储器中进行排序。

包括(交换式排序法,选择式排序法和插入式排序法);

2.外部排序法

数据量过大,无法全部加载到内存中,需要借助外部存储进行排序。包括(合并排序法和直接合并排序法)。

交换式排序法

交换式排序属于内部排序法,是运用数据值比较后,依判断规则对数据位置进行交换,以达到排序的目的。

交换排序法又可分为两种:

1.冒泡排序法(Bubble sort)

2.快速排序法(Quick sort)

交换式排序法-冒泡排序法

冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从后向前(从下标较大的元素开始),依次比较相邻元素的排序码,若发现逆序则交换,使排序码较小的元素逐渐从后部移向前部(从下标较大的单位移向下标较小的单元),就像水底下的气泡一样逐渐向上冒。

因为排序的过程中,各元素不断接近自己的位置,如果一趟比较下来没有进行过交换,就说明序列有序,因此要在排序过程中设置一个标志flag判断是否进行过交换。从而减少不必要的比较(优化)。

// 冒泡排序
func BubbleSort(arr *[5]int){
  fmt.Println("排序前arr=",(*arr))
  temp := 0
  // 冒泡排序
  for i:=0;i<len(*arr)-1;i++{
	 for j:=0;j<len(*arr)-1-i;j++{
		if(*arr)[j] > (*arr)[j+1]{
			// 交换
			temp = (*arr)[j]
			(*arr)[j] = (*arr)[j+1]
			(*arr)[j + 1] = temp
		}
	 }
   }
   fmt.Println("排序后arr=",(*arr))
}

查找

//顺序查找:方式一
for i := 0;i<len(names);i++{
   if heroName == names[i]{
	  fmt.Printf("找到%v,下标%v \n",heroName,i)
	}else if i==(len(names)-1){
		fmt.Printf("没有找到%v \n",heroName)
	}
}
// 顺序查找:方式二
index := -1
for i := 0;i<len(names);i++{
   if heroName == names[i]{
	  index = i
	}
}
if index != -1{
	fmt.Printf("找到%v,下标%v \n",heroName,index)
}else{
	fmt.Println("没有找到",heroName)
}

二分查找代码实现

func BinaryFind(arr *[6]int,leftIndex int,rightIndex int,findval int){
	// 判断leftIndex 是否大于 rightIndex
	if leftIndex > rightIndex{
		fmt.Println("找不到")
		return
	}
	// 先找到 中间的下标
	middle := (leftIndex + rightIndex)/2
	if(*arr)[middle] > findVal{
		// 说明我们要查找的数,应该在 leftIndex --- middle-1
		BinaryFind(arr,leftIndex,middle-1,findVal)
	}else if(*arr)[middle] < findVal{
		// 说明我们要查找的数,应该在 middle+1 --- rightIndex
		BinaryFind(arr,leftIndex,middle-1,findVal)
	}else{
		// 找到了
		fmt.Printf("找到了,下标为%v \n",middle)
	}
}

二维数组的介绍

多维数组我们只介绍二维数组

二维数组的应用场景

比如我们开发一个五子棋游戏,棋盘就是需要二维数组来表示。

二维数组快速入门

快速入门案例:

请使用二维数组输出如下图形

func main(){
	// 定义、声明一个数组
	var arr [4][6]int
	// 赋初值
	arr[1][2]=1
	arr[2][1]=2
	arr[2][3]=3
	// 遍历二维数组,按照要求输出图形
	for i :=0;i<4;i++{
		for j:=0;j<6;j++{
			fmt.Print(arr[i][j],"")
		}
		fmt.Println()
	}
}

使用方法1:先声明/定义,再赋值

1.语法:var 数组名 【大小】【大小】类型

2.比如:var arr [2][3]int,再赋值

3.使用演示

4.二维数组在内存中存在形式

使用方式2:直接初始化

声明:var 数组名【大小】【大小】类型 = 【大小】【大小】类型{{初始值…},{初始值…}}

赋值(有默认值,比如int 类型的就是0)

使用演示:

var arr3 [2][3]int = [2][3]int{{1,2,3},{4,5,6}}
fmt.Println("arr3=",arr3)

二维数组的使用

二维数组的遍历

双层for循环完成遍历

func main(){
 // 演示二维数组的遍历
 var arr3 = [2][3]int{{1,2,3},{4,5,6}}
 // for循环来遍历
 for i := 0;i<len(arr3);i++{
	for j:=0;j<len(arr3[i];j++){
		fmt.Printf("%v\t",arr3[i][j])
	}
	fmt.Println()
  }
  // for-range来遍历二维数组
  for i,v := range arr3{
	for j,v2 := range v{
	  fmt.Printf("arr3[%v][%v]=%v \t",i,j,v2)
	}
	fmt.Println()
  }
}

for-range方式完成遍历

func main(){
 // 演示二维数组的遍历
 var arr3 = [2][3]int{{1,2,3},{4,5,6}}
 // for循环来遍历
 for i := 0;i<len(arr3);i++{
	for j:=0;j<len(arr3[i];j++){
		fmt.Printf("%v\t",arr3[i][j])
	}
	fmt.Println()
  }
  // for-range来遍历二维数组
  for i,v := range arr3{
	for j,v2 := range v{
	  fmt.Printf("arr3[%v][%v]=%v \t",i,j,v2)
	}
	fmt.Println()
  }
}

二维数组的应用案例

定义二维数组,用于保存三个班,每个班五名同学成绩,求出每个班级平均分,以及所有班级平均分

func main(){
  // 定义一个二维数组
  var scores [3][5]float64
  // 循环的输入成绩
  for i:=0;i<len(scores);i++{
	for j:=0;j<len(scores[i]);j++{
		fmt.Printf("请输入第%d班的第%d个学生的成绩\n",i+1,j+1)
		fmt.Scanln(&scores[i][j])
	}
   }
   // 遍历输出成绩后的二维数组,统计平均分
   totalSum := 0.0 //定义一个变量,用于积累所有班级的总分
   for i := 0;i<len(scores);i++{
		sum := 0.0 // 定义一个变量,用于累积各个班级的总分
		for j := 0; j<len(scores[i]);j++{
			sum += scores[i][j]
		}
		totalSum += sum
		fmt.Printf("第%d班级的总分为%v,平均分为%v\n",i+1,sum,sum/float64(len(scores[i])))
	}
	fmt.Printf("所有班级的总分为%v,所有班级的平均分为%v\n",totalSum ,totalSum/15)
}

到此这篇关于Golang排序和查找使用方法介绍的文章就介绍到这了,更多相关Golang排序和查找内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • golang 各种排序大比拼实例

    1.准备工作 准备数据: 生成随机数并写入文件,之后在把数据读取出来 //新生成整数随机数,并存储在txt文件中, func NewIntRandm(fileName string, number, maxrandm int) { filename := fileName file, err := os.Create(filename) if err != nil { return } r := rand.New(rand.NewSource(time.Now().UnixNano())) ra

  • Golang实现常见排序算法的示例代码

    目录 前言 五种基础排序算法对比 1.冒泡排序 2.选择排序 3.插入排序 4.快速排序 前言 现在的面试真的是越来越卷了,算法已经成为了面试过程中必不可少的一个环节,你如果想进稍微好一点的公司,「算法是必不可少的一个环节」.那么如何学习算法呢?很多同学的第一反应肯定是去letcode上刷题,首先我并不反对刷题的方式,但是对于一个没有专门学习过算法的同学来说,刷题大部分是没什么思路的,花一个多小时暴力破解一道题意义也不大,事后看看别人比较好的解法大概率也记不住,所以我觉得「专门针对算法进行一些简

  • Golang 高效排序数据详情

    目录 1.介绍 2.切片排序 3.自定义集合排序 4总结 1.介绍 在 Golang 语言项目开发中,经常会遇到数据排序问题.Golang 语言标准库 sort 包,为我们提供了数据排序的功能,我们可以直接使用 sort.Sort() 函数进行数据排序,sort.Sort() 函数底层实现是以快排为主,并根据目标数据的具体情况选择不同的排序算法.本文我们介绍 sort 包排序数据的使用方法. 2.切片排序 在 Golang 语言标准库 sort 包中,sort.Sort() 函数用于数据排序,该

  • Golang排序和查找使用方法介绍

    目录 排序的介绍 交换式排序法 二维数组的介绍 二维数组的应用场景 二维数组快速入门 二维数组的使用 排序的介绍 排序是将一组数据,依指定的顺序进行排列的过程. 排序的分类: 1.内部排序: 指将需要处理的所有数据都加载到内部存储器中进行排序. 包括(交换式排序法,选择式排序法和插入式排序法): 2.外部排序法 数据量过大,无法全部加载到内存中,需要借助外部存储进行排序.包括(合并排序法和直接合并排序法). 交换式排序法 交换式排序属于内部排序法,是运用数据值比较后,依判断规则对数据位置进行交换

  • golang中使用mongo的方法介绍

    前言 笔者使用的mongo驱动是mgo, 这个使用的人比较多,文档也比较齐全 官网地址:http://labix.org/mgo 文档地址:https://godoc.org/labix.org/v2/mgo 源码地址:https://github.com/go-mgo/mgo 1. mgo包安装 go get gopkg.in/mgo.v2 但是貌似现在从gopkg.in下载不了,迂回一下,先从github上下载 go get github.com/go-mgo/mgo 下载好了之后,在$GO

  • Golang安装和使用protocol-buffer流程介绍

    目录 前言 安装protoc编译工具 编写proto文件 生成指定语言的proto文件 调用proto 制作插件 前言 protocol buffer是Google发布的一种独立的数据交换格式,类似于json,用于数据的序列化和解析.不同点是不能直接在各编程语言中使用,需要先在一个proto文件中定义需要传输的数据格式,然后使用proto工具把proto文件编译成想要的语言,如java.go.php等.然后在代码中,使用语言对应的protocol buffer包调用proto工具生成的文件,完成

  • c++自定义sort()函数的排序方法介绍

    目录 1. 引言 2. 自定义排序规则 2.1 重写 < 或 > 运算符 2.2 普通函数 2.3 仿函数 1. 引言 在C++中,sort()函数常常用来对容器内的元素进行排序,先来了解一下sort()函数. sort()函数有三个参数: 第一个是要排序的容器的起始迭代器. 第二个是要排序的容器的结束迭代器. 第三个参数是排序的方法,是可选的参数.默认的排序方法是从小到大排序,也就是less<Type>(),还提供了greater<Type>()进行从大到小排序.这个

  • JavaScript实现二叉树定义、遍历及查找的方法详解

    本文实例讲述了JavaScript实现二叉树定义.遍历及查找的方法.分享给大家供大家参考,具体如下: 二叉树(binary tree) 在写这篇文章之前说一下数据结构和算法这个系列,这个系列包含了很多东西,比如啥子排序,线性表,广义表,树,图这些大家都是知道的,但是这些东西我们学了之后工作中能用到的又有多少呢,据我所知绝大部分公司,一线码农,屌丝,程序猿是用不到这些东西,既然这样为啥子我还要强调这个系列呢,本人觉得算法和数据结构是程序的基本功,前提想脱离一线码农,普通程序猿行列,说得通俗一点就是

  • Golang连接Redis数据库的方法

    Golang连接Redis数据库 golang连接数据库,这里博主推荐使用go-redis这个库,理由很简单(连接数据库的操作类似在数据库里面输入命令) go-redis的安装方式 go get -v https://github.com/go-redis/redis -v小v,是输出过程.一般情况下不带-v什么反馈都看不到. 连接redis的方式 package ... import ( "github.com/go-redis/redis" ) func main() { clie

  • C++ push方法与push_back方法常见方法介绍

    目录 [摘要] [正文] 1.stack 2.queue [摘要] push与push_back是STL中常见的方法,都是向数据结构中添加元素.初识STL,对于添加元素的方法以产生混淆,这里暂对两种方法作出比较分析.此外,本文还将简述push对应的stack与queue系列,常见方法的介绍,以及与push_back相对应的vector系列常见方法介绍,详见下文. [正文] push_back 方法介绍 vector::void push_back (const value_type& val);

  • oracle中通配符和运算符的使用方法介绍

    用于where比较条件的有: 等于:=.<.<=.>.>=.<> 包含:in.not in exists.not exists 范围:between...and.not between....and 匹配测试:like.not like Null测试:is null.is not null 布尔链接:and.or.not 通配符: 在where子句中,通配符可与like条件一起使用.在Oracle中: %(百分号): 用来表示任意数量的字符,或者可能根本没有字符. _(

  • mysql中使用instr进行模糊查询方法介绍

    在mysql中使用内部函数instr,可代替传统的like方式查询,并且速度更快. instr 函数,第一个参数是字段,第二个参数是要查询的串,返回串的位置,第一个是1,如果没找到就是0. 例如,查询字段name中带"军"的名字,传统的方法是: select name from 用户表 where name like `%军%'; 用instr的方法: select name from 用户表 where instr('name','军'); 或: select name from 用

  • golang 函数以及函数和方法的详解及区别

    golang 函数以及函数和方法的区别 在接触到go之前,我认为函数和方法只是同一个东西的两个名字而已(在我熟悉的c/c++,python,java中没有明显的区别),但是在golang中者完全是两个不同的东西.官方的解释是,方法是包含了接收者的函数.到底什么意思呢. 首先函数的格式是固定的,func+函数名+ 参数 + 返回值(可选) + 函数体.例 func main() { fmt.Println("Hello go") } 在golang中有两个特殊的函数,main函数和ini

随机推荐