Go语言基础--for循环

for循环

for循环具有三个可选的组成部分:初始化语句(在循环开始前执行一次)、条件表达式(在每次循环开始前评估)、后处理语句(在每次循环体执行完毕后执行)。Go语言中的循环语句只支持for关键字,而不支持while和do-while结构。

for 初始化语句; 条件表达式; 后处理语句 {

// 循环体

}

  • 初始化语句:在循环开始前执行,通常用于初始化一个或多个计数器变量。
  • 条件表达式:在每次循环开始前评估。如果条件为真(true),则执行循环体;如果为假(false),则终止循环。
  • 后处理语句:在每次循环体执行完毕后执行,通常用于更新计数器变量。

示例:

for i := 0; i <= 10; i++ {

fmt.Println(i)

}

for循环其他格式

i := 0

for i<=10; {

fmt.Println(i)

i++

}
i := 0

for {

if i<=10{

fmt.Println(i)

} else {

break

}

i++

}

如果不加break会输出0--10之后继续循环,但是不会再打印,因为是无限循环,go语言中没有缩进要求,只要在括号里就可以

for...range循环

for...range循环用于遍历数组、切片、字符串、映射(map)或通道(channel)的元素。它会自动处理索引和值(对于映射,则是键和值)。

for 索引, 值 := range 集合 {

// 循环体

}

  • 索引:对于数组、切片、字符串,是元素的索引;对于映射,是键。
  • :集合中对应索引或键的

示例:

  • 遍历切片:

slice := []int{1, 2, 3, 4, 5}

for index, value := range slice {

fmt.Printf("Index: %d, Value: %d\n", index, value)

}

  • 遍历字符串:

原本的方式遍历

var str string = "I like 黑神话悟空"

str2 :=[]rune(str)

for i :=0; i<len(str2); i++{

fmt.Printf("%c \n", str2[i])

}
var str string = "I like 黑神话悟空"

for index,value := range str{

fmt.Printf("index=%d, value=%c \n",index,value)

}

忽略索引:

var str string = "I like 黑神话悟空"

for _,value := range str {

fmt.Printf("value=%c \n", value)

}

  • 遍历映射:

m := map[string]int{"a": 1, "b": 2, "c": 3}

for key, value := range m {

fmt.Printf("Key: %s, Value: %d\n", key, value)

}

无限循环

如果省略了for循环的初始化语句、条件表达式和后处理语句,它将成为一个无限循环,直到你显式地通过break语句退出循环或使用return语句从包含它的函数返回。

for {

// 循环体

// 可以通过break语句退出循环

}

示例:

for {

fmt.Println("这是一个无限循环,需要手动停止!")

// 假设这里有一些条件判断,满足条件时退出循环

// break

}

案例

算出来1-88能被9整除的数量和累计和

package main

import "fmt"

func main() {

var a int = 88

var count int = 0

var sum int = 0

for i:=1; i<=a; i++ {

if i%9 == 0 {

count++

sum += i

}

}

fmt.Println(count,sum)

}

相关推荐
计算机小白一个6 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^6 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿8 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!8 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉8 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生8 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴8 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing8 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财8 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程8 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛