hello-algo/en/codes/go/chapter_computational_complexity/iteration.go

60 lines
969 B
Go

// File: iteration.go
// Created Time: 2023-08-28
// Author: Reanon (793584285@qq.com)
package chapter_computational_complexity
import "fmt"
/* for loop */
func forLoop(n int) int {
res := 0
// Loop sum 1, 2, ..., n-1, n
for i := 1; i <= n; i++ {
res += i
}
return res
}
/* while loop */
func whileLoop(n int) int {
res := 0
// Initialize condition variable
i := 1
// Loop sum 1, 2, ..., n-1, n
for i <= n {
res += i
// Update condition variable
i++
}
return res
}
/* while loop (two updates) */
func whileLoopII(n int) int {
res := 0
// Initialize condition variable
i := 1
// Loop sum 1, 4, 10, ...
for i <= n {
res += i
// Update condition variable
i++
i *= 2
}
return res
}
/* Double for loop */
func nestedForLoop(n int) string {
res := ""
// Loop i = 1, 2, ..., n-1, n
for i := 1; i <= n; i++ {
for j := 1; j <= n; j++ {
// Loop j = 1, 2, ..., n-1, n
res += fmt.Sprintf("(%d, %d), ", i, j)
}
}
return res
}