douyueqing1530 2016-08-24 18:28
浏览 46
已采纳

如何在Golang中比较结构数据和接口数据?

I am trying to create a generic Binary Tree in Golang. How can I compare data from an interface and input data in the code? Here is an example of what I am trying to do. The comparison that is giving me trouble is this

 } else if cur.data < data {

-

package DSAA

type TreeNode struct {
    data interface{}
    right *TreeNode
    left *TreeNode
}

type BinarySearchTree struct {
    root *TreeNode
}

func BSTCreate() *BinarySearchTree {
    return &BinarySearchTree{nil}
}

func (b *BinarySearchTree) Insert(cur TreeNode, data interface{}) *BinarySearchTree {
    if &cur == nil {
        cur := &TreeNode{data, nil, nil}
    } else if cur.data < data {
        b = b.Insert(*cur.left, data)
    } else {
        b = b.Insert(*cur.right, data)
    }
    return b
}
  • 写回答

1条回答 默认 最新

  • douban5644 2016-08-24 18:49
    关注

    You have some options:
    1- Using runtime type switch:

    package main
    
    import (
        "fmt"
    )
    
    func main() {
        fmt.Println(Less(1, 2))       // true
        fmt.Println(Less("AB", "AC")) // true
    }
    
    func Less(a, b interface{}) bool {
        switch v := a.(type) {
        case int:
            w := b.(int)
            return v < w
        case string:
            w := b.(string)
            return v < w
    
        }
        return false
    }
    

    then replace } else if cur.data < data { with } else if Less(cur.data , data) {


    2- Using Comparer interface:

    package main
    
    import (
        "fmt"
    )
    
    type Comparer interface {
        // Less reports whether the element  is less than b
        Less(b interface{}) bool
    }
    
    func main() {
        a, b := Int(1), Int(2)
        fmt.Println(a.Less(b)) // true
    
        c, d := St("A"), St("B")
        fmt.Println(c.Less(d)) // true
    }
    
    type Int int
    
    func (t Int) Less(b interface{}) bool {
        if v, ok := b.(Int); ok {
            return int(t) < int(v)
        }
        return false
    }
    
    type St string
    
    func (t St) Less(b interface{}) bool {
        if v, ok := b.(St); ok {
            return string(t) < string(v)
        }
        return false
    }
    

    3- Using reflect

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器