题目 1452: 网络寻路

题目描述:

X 国的一个网络使用若干条线路连接若干个节点。节点间的通信是双向的。某重要数据包,为了安全起见,必须恰好被转发两次到达目的地。该包可能在任意一个节点产生,我们需要知道该网络中一共有多少种不同的转发路径。

源地址和目标地址可以相同,但中间节点必须不同。

如下图所示的网络。

1 -> 2 -> 3 -> 1 是允许的

1 -> 2 -> 1 -> 2 或者 1 -> 2 -> 3 -> 2 都是非法的。

代码:

java 复制代码
package lanqiao;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;


public class Main {
    static boolean vis[] = new boolean[10010]; //记录走过的节点
    static ArrayList<ArrayList<Integer>> map = new ArrayList<ArrayList<Integer>>(); //邻接表
    static int ans = 0;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        for(int i = 0;i <= n;i ++) //初始化节点,将下标为0的节点置为-1
        {
            map.add(new ArrayList<Integer>());
            map.get(i).add(-1);
        }

        for(int i = 1;i <= m;i ++)
        {
            int u = sc.nextInt();
            int v = sc.nextInt();
            map.get(u).add(v);
            map.get(v).add(u);
        }
        Arrays.fill(vis,false); //初始化vis数组
        for(int i = 1;i <= n;i ++)
        {
            vis[i] = true;
            dfs(i,1,i);
            vis[i] = false;
        }
        System.out.println(ans);
    }

    static void dfs(int cur,int step,int root) { //cur:当前节点,step:节点数,root:第一个节点
        if (step == 3) {  //当节点数正好为3时
            for (int i = 1; i < map.get(cur).size(); i++) {
                if (!vis[map.get(cur).get(i)] || map.get(cur).get(i) == root) {  //判断第四个节点是否为第一个节点或者是没有走过的节点
                    ans++;
                }
            }
        } else {
            for (int i = 1; i < map.get(cur).size(); i++) {
                if (!vis[map.get(cur).get(i)]) {
                    vis[map.get(cur).get(i)] = true;
                    dfs(map.get(cur).get(i), step + 1, root);
                    vis[map.get(cur).get(i)] = false;
                }
            }
        }
    }
}
相关推荐
啊哦呃咦唔鱼5 分钟前
LeetCode hot100-240搜索二维矩阵 II
算法
Q741_1476 分钟前
力扣高频面试题详解 数组 链表 力扣 56.合并区间 力扣 160.相交链表 C++ 每日练习
c++·算法·leetcode·链表·数组·哈希
2301_7938046914 分钟前
C++中的备忘录模式
开发语言·c++·算法
ab15151716 分钟前
3.23完成进阶45、84,二刷基础132、129
算法·深度优先·图论
CoovallyAIHub17 分钟前
编码智能体做 CV 任务,实际能力到哪一步了?——五项视觉任务实测解读
深度学习·算法·计算机视觉
2501_9454235419 分钟前
C++编译期多态实现
开发语言·c++·算法
2401_8796938719 分钟前
设计模式在C++中的实现
开发语言·c++·算法
☆56622 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
2301_8184190124 分钟前
编译器命令选项优化
开发语言·c++·算法
m0_5180194824 分钟前
C++图形编程(OpenGL)
开发语言·c++·算法