DFS回溯题:奇偶交错排列

梦想不抛弃苦心追求的人,只要不停止追求,你们会沐浴在梦想的光辉之中。再美好的梦想与目标,再完美的计划和方案,如果不能尽快在行动中落实,最终只能是纸上谈兵,空想一番。只要瞄准了大方向,坚持不懈地做下去,才能够扫除挡在梦想前面的障碍,实现美好的人生蓝图。DFS回溯题:奇偶交错排列,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

DFS回溯题:奇偶交错排列

问题:

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

思路:

使用DFS回溯法解决
关于DFS回溯法,它并不是一种具体的算法,应该说是一种思想
DFS的基本思想:
1:一条路走到底。
2:只有当前状态不存在任何后继状态时,才返回至上一层状态(也就是从哪来回哪去)
3:一旦从该状态返回,说明该状态及其后继状态都已经访问过,故无需再次访问。

对于本题,要求求解相邻数字奇偶性不同的全排列。我们可以使用dfs函数逐位遍历所有情况,由于每个数字在排列中只能出现一次,因此我们使用visit[]数组保存一个数字是否出现过。又因为相邻数字要求奇偶性不同,我们需保存上一位数字的奇偶性,以决定当前位可选哪些数字。
选取当前位数字时,从1~n中选择满足条件的数字,之后调用下一位的dfs函数,dfs函数返回,即表示当前分支已走完,将当前位数字的visit重置,即回溯到上一层状态

dfs函数的参数有保存每位数字的数组array,当前位的下标now,上一位数字的奇偶性last,题目给定的n,以及visit数组。设now从1开始,当now == n+1时,表示已经得到一个排列,dfs返回

在这里插入图片描述
需注意的点

  • 判断i的奇偶性使用( i & 1 ),即i和1相与,若i为奇数,和1相与得到1,否则得0

代码:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n;
        int[] array = new int[12];
        int[] visit = new int[12];
        while (scanner.hasNextInt()) {
            Arrays.fill(visit, 0);
            n = scanner.nextInt();
            dfs(array, 1, -1, n, visit);
        }

    }

    static void dfs(int[] array, int now, int last, int n, int[] visit) {
        int i;
        if (now == n + 1) {
            for (i = 1;i <= n;i++) {
                System.out.print(array[i] + " ");
            }
            System.out.print('\n');
        }
        for (i = 1;i <= n;i++) {
            if (visit[i] == 0 && last != (i & 1)) {
                array[now] = i;
                visit[i] = 1;
                dfs(array, now + 1, i & 1, n, visit);
                visit[i] = 0;
            }
        }
    }
}

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

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/153755.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!