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)

}

相关推荐
黑色的山岗在沉睡2 分钟前
LeetCode100.4 移动零
数据结构·算法·leetcode
方博士AI机器人21 分钟前
算法与数据结构 - 二叉树结构入门
数据结构·算法·二叉树
-qOVOp-30 分钟前
zst-2001 上午题-历年真题 算法(5个内容)
算法
全栈凯哥44 分钟前
Java详解LeetCode 热题 100(17):LeetCode 41. 缺失的第一个正数(First Missing Positive)详解
java·算法·leetcode
ai.Neo1 小时前
牛客网NC22157:牛牛学数列2
数据结构·c++·算法
Nobkins2 小时前
2023CCPC河南省赛暨河南邀请赛个人补题ABEFGHK
开发语言·数据结构·c++·算法·图论
王RuaRua2 小时前
[数据结构]7. 堆-Heap
c语言·数据结构·算法·链表
朱剑君2 小时前
第八天——贪心算法——队列重构问题
算法·贪心算法·重构
仙人掌_lz2 小时前
深度理解用于多智能体强化学习的单调价值函数分解QMIX算法:基于python从零实现
python·算法·强化学习·rl·价值函数
riri19193 小时前
算法分析:蛮力法
数据结构·算法