IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 算法提高 全排列 -> 正文阅读

[数据结构与算法]算法提高 全排列

输入一个n输出自然数1输出自然数1到n所有不重复的排列,即n的全排列。到n所有不重复的排列,即n的全排列

排列算法参考:https://www.nayuki.io/page/next-lexicographical-permutation-algorithm

import java.util.*;
public class Main {
	public static boolean nextPermutation(int[] array) {
		int i=array.length-1;
		while(i>0&&array[i-1]>=array[i])	i--;//找寻最长不递增序列
		if(i<=0) return false;//已经是最大了
		int j=array.length-1;
		while(array[j]<=array[i-1]) j--;//从最右开始寻找比i-1大的下标为j
		int temp=array[i-1];
		array[i-1]=array[j];
		array[j]=temp;//交换
		j=array.length-1;
		while(i<j) {
			temp=array[i];
			array[i]=array[j];
			array[j]=temp;
			i++;j--;
		}
		//成功完成
		return true;
	}
	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();
		int[] m=new int [n];
		for(int i=0;i<n;i++) {
			m[i]=i+1;
		}
		for(int i=0;i<n;i++)
		System.out.print(m[i]+" ");
		System.out.println();
		for(;nextPermutation(m);) {
			for(int j=0;j<m.length;j++) {
				System.out.print(m[j]+" ");
			}
			System.out.println();
		}
	}
}

dfs搜索算法

import java.util.*;

public class Main {
	static int n;
	static int[] line=new int[10];
	static int[] visit=new int[10]; 
	public static void print() {
		for(int i=1;i<=n;i++) 
			System.out.printf("%d",line[i]);
		System.out.println();
		return ;
	}
	public static void dfs(int step) {//每组第step个数
		if(step>n) {//搜索完了,输出
			print();
		}
		for(int i=1;i<=n;++i) {
			if(visit[i]==1);
			else {
				line[step]=i;//第step个赋值为i
				visit[i]=1;//已经访问
				dfs(step+1);//递归调用
				visit[i]=0;//不使用数值了
			}
		}
		return ;
	}
	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		n=sc.nextInt();
		dfs(1);
	}
	
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:38:43  更:2022-04-01 23:41:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 5:06:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码