Java 递归、DFS、回溯

Java 递归、DFS、回溯DFS/回溯算法如果某问题的解可以由多个步骤得到,而每个步骤都有若干种选择(这些候选方案集可能会依赖之前做出的选择),且可以用递归枚举法实现,则它的工作方式可以用解答树来描述。全排列问题输出数字1~N所能组成的所有全排列publicclassA{/***全排列**@paramargs*/staticVector<Integer>vector=newVector<>();s

大家好,又见面了,我是你们的朋友全栈君。

DFS/回溯算法

如果某问题的解可以由多个步骤得到,而每个步骤都有若干种选择(这些候选方案集可能会依赖之前做出的选择),且可以用递归枚举法实现,则它的工作方式可以用解答树来描述。

全排列问题

输出数字1~N所能组成的所有全排列

在这里插入图片描述

public class A { 
   
    /** * 全排列 * * @param args */

    static Vector<Integer> vector = new Vector<>();

    static int N = 0;

    static boolean[] isUsed = new boolean[100];

    public static void main(String[] args) { 
   

        N = 3;
        dfs(0);
    }

    static void dfs(int n) { 
   
        if (n >= N) { 
   
            for (Integer integer : vector) { 
   
                System.out.print(integer);
            }
            System.out.println();
            return;
        }
        for (int i = 1; i <= N; i++) { 
   
            if (isUsed[i]) { 
   
                continue;
            }
            vector.add(i);
            isUsed[i] = true;
            dfs(n + 1);
            Integer integer = vector.lastElement();
            vector.remove(integer);
            isUsed[i] = false;
        }

    }

}

素数环问题

将1到n这n个整数围成一个圆环,若其中任意2个相邻的数字相加,结果均为素数,那么这个环就成为素数环。

例如数字1-6所组成的一个素数环,用数组表示是[1, 4, 3, 2, 5, 6](第一位固定为1)

图一:

在这里插入图片描述

图二、在这里插入图片描述

public class B { 
   

    static int N = 6;
    static Vector<Integer> vector = new Vector<>();


    static boolean[] isUsed = new boolean[100];

    /** * 1 - n 之间的 * 素数环 * * @param args */
    public static void main(String[] args) { 
   
        System.out.println(8 & 1);

        vector.add(1);
        dfs(1);
    }

    static void dfs(int n) { 
   
        // 打印结果
        if (n >= N) { 
   
            int temp = vector.firstElement() + vector.lastElement();
            if (isPri(temp) == false) { 
   
                return;
            }
            for (Integer integer : vector) { 
   
                System.out.print(integer);
            }
            System.out.println();
        }

        for (int i = 2; i <= N; i++) { 
   

            if (isUsed[i]) { 
   
                continue;
            }
            int temp = vector.get(n - 1) + i;
            // 剪枝
            if (isPri(temp) == false) continue;

            vector.add(i);
            isUsed[i] = true;

            dfs(n + 1);

            isUsed[i] = false;

            Integer lastElement = vector.lastElement();
            vector.remove(lastElement);
        }

    }

    static boolean isPri(int n) { 
   
        int ans = n & 1;
        if (ans == 0) { 
   
            return false;
        } else { 
   
            return true;
        }
    }


}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/156770.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月8日 下午10:46
下一篇 2022年7月8日 下午10:46


相关推荐

  • DHCP协议工作流程

    DHCP协议工作流程一个全新主机的请求一次DHCP服务的过程主要包含以下四个步骤第一步:客户机操作系统生成一个DHCPdiscover发现报文,被放置在一个具有广播IP目的地址(255.255.255.255)和源IP地址为0.0.0.0的IP数据报中(网络层),发送到以太网,试图找到网络中DHCP服务器以获取一个IP地址。这一步可以简化为DHCPdiscover,源IP:0.0.0.0,目的IP:255.255.255.255,表示客户机说我需要一个IP,DHCP你在哪,能不能分我一个?第二步:当运行在路

    2022年5月23日
    47
  • 【PyCharm实用教程】最详细的Pycharm使用教程,你真不要进来学习一下?

    【PyCharm实用教程】最详细的Pycharm使用教程,你真不要进来学习一下?目录 1 PyCharm 的安装 2 编写代码 3 如何运行代码 4 进行代码的调试 5 进行代码测试 6 编辑已有项目 7 使用搜索和导航 8 配置版本控制系统 VCS 9 使用插件和外部工具 10 PyCharmProfe 功能 11 数据库支持 12 Profiler 性能分析 13 科学模式 14 远程开发 15 写在最后本文假设读者熟悉 Python 开发 且计算机中已安装某个版本的 Python 该教程将使用 Py

    2026年3月27日
    2
  • Tensorfow中使用tf.identity()的作用

    Tensorfow中使用tf.identity()的作用先来看 TensorFlow 中对 identity 的定义 defidentity input name None nbsp pylint disable redefined builtin nbsp

    2025年7月7日
    3
  • idea创建maven工程_idea创建一个java项目

    idea创建maven工程_idea创建一个java项目IntelliJ IDEA + Maven创建Java Web项目

    2022年4月21日
    78
  • Origin绘图快速上手指南

    Origin绘图快速上手指南1、创建工程打开origin后,点击菜单栏“文件”,选择“项目另存为”,给项目命名,并存到某个工作路径。2、导入数据然后将excel中的数据(只要数据)选中后复制到Book1中,从第5行开始粘贴。可以在侧面打开“项目管理器”,给表格“Book1”重命名为“曲线数据”。还可以在表格的“长单位”处给每列数据加上标签。3、那么这时可以直接使用Origin的自动绘图功能了。选择A、B、C所有列,然后点击菜单栏的“绘图”,选择一个折线图,双击即可绘图。这样呢就是将两条曲线放到同一张图中了。如果想要自定

    2022年5月31日
    56
  • matplotlib颜色代码_matplotlib color

    matplotlib颜色代码_matplotlib color命令形如:plt.plot(x,y,linewidth=’1′,label=”test”,color=’red’,linestyle=’:’,marker=’|’)plt.legend(loc=’upperleft’)plt.show()线条形式(linestyle):’-‘solidlinestyle’–‘dashedli…

    2022年10月15日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号