1129. 颜色交替的最短路径(leetcode,广搜,可重做)-------------------Java实现

1129. 颜色交替的最短路径(leetcode,广搜,可重做)-------------------Java实现

题目表述

给定一个整数 n,即有向图中的节点数,其中节点标记为 0 到 n - 1。图中的每条边为红色或者蓝色,并且可能存在自环或平行边。

给定两个数组 redEdges 和 blueEdges,其中:

redEdges[i] = [ai, bi] 表示图中存在一条从节点 ai 到节点 bi 的红色有向边,

blueEdges[j] = [uj, vj] 表示图中存在一条从节点 uj 到节点 vj 的蓝色有向边。

返回长度为 n 的数组 answer,其中 answer[X] 是从节点 0 到节点 X 的红色边和蓝色边交替出现的最短路径的长度。如果不存在这样的路径,那么 answer[x] = -1。

样例

n =5

redEdges =[[0,1],[1,2],[2,3],[3,4]]

blueEdges =[[1,2],[2,3],[3,1]]

条件

1 <= n <= 100

0 <= redEdges.length, blueEdges.length <= 400

redEdges[i].length == blueEdges[j].length == 2

0 <= ai, bi, uj, vj < n

思路

通过一个二维[n][2]List来记录当前点可以到达的下个点。

广搜,搜索记录到达点的长度。

注意点

x^1 可实现 x1时返回0,x0时返回1,异或运算。

ac代码

Java:

java 复制代码
package leetcode1129;

import java.util.*;

class Solution {
    public int[] shortestAlternatingPaths(int n, int[][] redEdges, int[][] blueEdges) {
    List<Integer> target[][] = new List[n][2];
    int[][] visit = new int[n][2];
    int max = 10000009;
    for (int i=0;i<n;i++) {
        target[i][0] = new ArrayList<Integer>();
        target[i][1] = new ArrayList<Integer>();
        visit[i][0] = max;
        visit[i][1] = max;
    }
    for (int[] x:redEdges)
        target[x[0]][0].add(x[1]);
        for (int[] x:blueEdges)
            target[x[0]][1].add(x[1]);
        Queue<Integer[]> q = new LinkedList<>();
        q.offer(new Integer[]{0,0});
        q.offer(new Integer[]{0,1});
        int this_step = 0;
        while(!q.isEmpty())
        {
            int this_longth = q.size();
            while(this_longth--!=0)
            {
                Integer[] now_sit = q.poll();
                if (visit[now_sit[0]][now_sit[1]]!=max)
                    continue;
                else
                    visit[now_sit[0]][now_sit[1]]=this_step;
                for (Integer now:target[now_sit[0]][now_sit[1]^1])
                    q.offer(new Integer[]{now,now_sit[1]^1});
            }
            this_step++;
        }
        int[] result = new int[n];
        for (int i=1;i<n;i++) {
            result[i] = Math.min(visit[i][0], visit[i][1]);
            if (result[i]==max)
                result[i] =-1;
        }
        return result;
    }
}

public class leetocde1129 {
    public static void main(String[] args) {
        int n = 5;
        int[][] red_edges = new int[][]{
                {0,1},{1,2},{2,3},{3,4}
        };
        int[][] blue_edges = new int[][]{{1,2},{2,3},{3,1}};
        Solution s = new Solution();
        int[] result = s.shortestAlternatingPaths(n,red_edges,blue_edges);
    for (int x:result)
        System.out.println(x+" ");
    };



        }
相关推荐
j_xxx404_1 分钟前
力扣C++算法:哈希表(存在重复元素|存在重复元素II|字母异位词分组)
算法·leetcode·散列表
穿条秋裤到处跑1 分钟前
每日一道leetcode(2026.04.17):镜像对之间最小绝对距离
算法·leetcode
下地种菜小叶2 分钟前
接口幂等怎么设计?一次讲清重复提交、支付回调、幂等键与防重落地方案
java·spring boot·spring·kafka·maven
codebrick2 分钟前
408 数据结构:快排 / 堆排 / 归并 / 希尔 等排序算法对比(复杂度、稳定性、真题考点
数据结构·考研·算法·排序算法·408
脱氧核糖核酸__2 分钟前
LeetCode热题100——240.搜索二维矩阵 II(题目+题解+答案)
c++·算法·leetcode·矩阵
YDS8293 分钟前
大营销平台 —— 模板方法串联前中置抽奖规则
java·spring boot·ddd
.柒宇.3 分钟前
Java八股之== 与 equals 区别
java·开发语言
时间静止不是简史4 分钟前
当MyBatis-Plus的like遇上SQL通配符:下划线翻车记
java·sql·mybatis
两年半的个人练习生^_^7 分钟前
每日一学:设计模式之建造者模式
java·开发语言·设计模式
纤纡.8 分钟前
基于 TextRNN 的微博情绪分类系统实现与解析
人工智能·算法·分类·数据挖掘