golang 去练习
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang 去练习相关的知识,希望对你有一定的参考价值。
package main
import (
"golang.org/x/tour/tree"
"fmt"
)
// Walk 步进 tree t 将所有的值从 tree 发送到 channel ch。
func Walk(t *tree.Tree, ch chan int) {
_walk(t, ch)
close(ch)
}
// tree.New 似乎构建的并不是随机结构的二叉树
func WalkRecur(t *tree.Tree, ch chan int) {
if t == nil {
return
}
ch <- t.Value
WalkRecur(t.Left, ch)
WalkRecur(t.Right, ch)
}
func _walk(t *tree.Tree, ch chan int) {
if t != nil {
_walk(t.Left, ch)
ch <- t.Value
_walk(t.Right, ch)
}
}
// Same 检测树 t1 和 t2 是否含有相同的值。
func Same(t1, t2 *tree.Tree) bool {
ch1 := make(chan int)
ch2 := make(chan int)
go Walk(t1, ch1)
go Walk(t2, ch2)
// 树的结构都相同,因此可以使用这个算法。不然,应该使用Set来判断值是否唯一。
for i := range ch1 {
if i != <- ch2 {
return false
}
}
return true
}
func main() {
ch := make(chan int)
go Walk(tree.New(1), ch)
for i := range ch {
fmt.Println(i)
}
fmt.Println("----")
fmt.Println(Same(tree.New(1), tree.New(2)))
fmt.Println(Same(tree.New(1), tree.New(1)))
}
golang sqrt error练习
练习:错误
从先前的练习中复制 Sqrt
函数,并修改使其返回 error
值。
由于不支持复数,当 Sqrt
接收到一个负数时,应当返回一个非 nil 的错误值。
创建一个新类型
type ErrNegativeSqrt float64
为其实现
func (e ErrNegativeSqrt) Error() string
使其成为一个 error
, 该方法就可以让 ErrNegativeSqrt(-2).Error()
返回 `"cannot Sqrt negative number: -2"`。
*注意:* 在 Error
方法内调用 fmt.Sprint(e)
将会让程序陷入死循环。可以通过先转换 e
来避免这个问题:fmt.Sprint(float64(e))
。请思考这是为什么呢?
修改 Sqrt
函数,使其接受一个负数时,返回 ErrNegativeSqrt
值。
参考解法:
package main
import (
"fmt"
)
type ErrNegativeSqrt float64
func (e ErrNegativeSqrt) Error() string {
return fmt.Sprintf("cannot Sqrt negative number: %f", e)
}
func Sqrt(x float64) (float64, error) {
if x < 0 {
return 0, ErrNegativeSqrt(x)
}
z := 1.0
for i := 0; i < 20; i++ {
z = z - (z*z-x)/(2*x)
}
return z, nil
}
func main() {
nums := []float64{4, -6, 8, 10}
for _, v := range nums {
sqrv, e := Sqrt(v)
if e == nil {
fmt.Printf("sqrt(%f)=%f\n", v, sqrv)
} else {
fmt.Println(e)
}
}
}
以上是关于golang 去练习的主要内容,如果未能解决你的问题,请参考以下文章
golang sqrt error练习
golang 练习:斐波纳契闭合
golang基础练习
Golang之函数练习
golang-练习1
golang-练习ATM