【Go每日一练】返回切片中的最大值和最小值

👻创作者:丶重明
👻创作时间:2025年3月7日
👻擅长领域:运维

目录

😶‍🌫️题目:

编写一个函数,接收一个整数切片,并返回切片中的最大值和最小值

😶‍🌫️要求:

  • 函数名为findMinMax
  • 输入参数为一个整数切片 []int
  • 返回值为两个整数,分别表示最小值和最大值

😶‍🌫️资源:

有一组随机生成的整数:

go 复制代码
3, 23, 43, 5436, 23, 36, 68, 443, 27

😶‍🌫️代码:

go 复制代码
package main

import "fmt"

func findMinMax(nums []int) (int, int) {
	if len(nums) == 0 {
		return 0, 0
	}
	min, max := nums[0], nums[0]
	for _, num := range nums {
		if num < min {
			min = num
		}
		if num > max {
			max = num
		}
	}
	return min, max
}

func main() {
	input := []int{3, 23, 43, 5436, 23, 36, 68, 443, 27}
	min, max := findMinMax(input)
	fmt.Printf("最大的数字是: %d\n最小的数字是: %d", max, min)
}

😶‍🌫️输出:

go 复制代码
> go run .\3.go_fmt.go
最大的数字是: 5436
最小的数字是: 3

😶‍🌫️解析:

go 复制代码
func findMinMax(nums []int) (int, int) {...}
  • 一个名为findMinMax的自定义函数,接收一个整数切片nums作为参数
  • 这个函数返回两个int整数类型的值
go 复制代码
	// len表示长度
    if len(nums) == 0 {
        return 0, 0
    }
  • 检查切片nums是否为空,如果长度=0,则返回两个0
go 复制代码
    min, max := nums[0], nums[0]
  • 初始化minmax变量,将它们都复制切片的第一个元素(切片中第一个元素用0表示)
go 复制代码
    for _, num := range nums {
        if num < min {
            min = num
        }
        if num > max {
            max = num
        }
    }
  • for循环中使用range关键字遍历nums切片中每个元素
  • _表示空白标识符,表示忽略返回的第一个值
  • 对于每个元素num,如果它小于当前的min,则更新min为num
  • 如果它大于当前的max,则更新max为num
go 复制代码
    return min, max
  • 遍历结束后,函数返回min和max,即切片中的最小值和最大值
go 复制代码
func main() {
	input := []int{3, 23, 43, 5436, 23, 36, 68, 443, 27}
	min, max := findMinMax(input)
	fmt.Printf("最大的数字是: %d\n最小的数字是: %d", max, min)
}
  • 定义一个整数切片input,并初始化一些整数
  • 调用findMinMax函数,将input切片作为参数传递给它,并将返回的最小值和最大值赋值给minmax变量
  • 然后使用fmt.Printf函数格式化输出结果
相关推荐
电鱼智能的电小鱼4 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun5 小时前
【算法】图相关算法和递归
windows·python·算法
QX_hao6 小时前
【Go】--反射(reflect)的使用
开发语言·后端·golang
格图素书6 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector7 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会7 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗7 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚7 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实7 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
hweiyu008 小时前
Go、DevOps运维开发实战(视频教程)
开发语言·golang·运维开发