leetcode_1042

淳属虚构 · · 1036 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

Golang:

思路:看似简单实则不简单的简单题,首先,这是个图问题,个人的思路是,先形成邻接表,然后对表里的每一个点依次进行赋值,怎么赋值呢?拿到表里的点,看一下与它构成边的那些点是否被赋值了,被赋值了,就考虑下还能给这个点哪些值,然后赋值该点

代码如下:

func gardenNoAdj(N int, paths [][]int) []int {
    if N==0 {
        return nil
    }
    //先遍历整个paths
    //还是需要一个长度为N+1的数组
    //存在没有出现在path中的点,即单独的花园,数组上这些点全部赋值为1
    //还是用一个map去存放邻接表,不要使用数组,万一大部分花园都是单独存在的,会浪费空间
    //遍历数组,当数组元素为0,去map中找这个元素的邻接表,看下那几个元素被用了,判断元素被用的点,我想也用一个used数组来表示
    used:=make([]int,N+1)
    vertex:=make(map[int][]int)
    for _,v:=range paths{
        vertex[v[0]]=append(vertex[v[0]],v[1])
        vertex[v[1]]=append(vertex[v[1]],v[0])
        used[v[0]],used[v[1]]=-1,-1
    }
    flowers:=[5]int{0,0,0,0,0}
    for i:=1; i<=N; i++{
        if used[i]!=-1 {
            used[i]=1
            continue
        }
        for j:=0;j<len(vertex[i]);j++{
            if used[vertex[i][j]]!=-1 {
                flowers[used[vertex[i][j]]]=1
            }
        }
        for j:=1;j<len(flowers);j++{
            if flowers[j]==0 {
                used[i]=j
                break
            }
        }
        for j:=1;j<=4;j++{
            flowers[j]=0
        }
    }
    res:=used[1:]
    return res
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:淳属虚构

查看原文:leetcode_1042

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1036 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传