【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函数格式化输出结果
相关推荐
福大大架构师每日一题24 分钟前
2026年6月TIOBE编程语言排行榜,Go语言排名第13,Rust语言排名12。关于Rust已进入平台期的报道似乎为时过早。
开发语言·golang·rust
羊羊小栈36 分钟前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业
金融小师妹1 小时前
AI因子共振模型显示:金银比突破区间上沿,白银定价逻辑进入再校准阶段
人工智能·算法·均值算法·线性回归
J2虾虾1 小时前
C语言 typedef 用法
c语言·数据结构·算法
hunterkkk(c++)1 小时前
线段树例题
算法
故渊at2 小时前
第二板块:Android 四大组件标准化学理 | 第七篇:Activity 页面载体与任务栈算法
android·算法·生命周期·activity·任务栈
兰令水2 小时前
leecodecode【区间DP+树形DP】【2026.6.10打卡-java版本】
java·算法·leetcode
weixin199701080162 小时前
[特殊字符] 1688开放平台API Sign签名算法详解(Java / Python / PHP 实现)
java·python·算法
未若君雅裁2 小时前
JVM 垃圾回收算法与分代回收机制
java·jvm·算法