深度优先搜索之n个数的排列组合

思路:方法一:可直接用暴力枚举法

方法二:dfs

此处列出n为3的情况

//step=1设为第一个桶,=2,设为第二个桶,一次类推
public class Algotirhm{
static int n=3;
static int []arr=new int[n+1];
static int []book=new int[n+1];
public static void DFS(int step){
if(step==(n+1)){                        //临界条件前n个桶已放数,当temp==n+1时,表示该输出了

for(int i=1;i<=n;i++)
System.out.print(arr[i]);
System.out.println();
return;
}
for(int i=1;i<=n;i++){
if(book[i]==0){   //==0 表示没放
book[i]=1;   //标记已放
arr[step]=i;//表示第step个桶放的数为i
DFS(step+1);
book[i]=0;//取消时,要设为没放
}
}
return;
}

public static void main(String[] args) {
Scanner s=new  Scanner(System.in);

DFS(1);

}
}

全部评论

相关推荐

最近和朋友聊天,她说了句让我震惊的话:"我发现我连周末点外卖都开始'最优解'了,一定要赶在高峰期前下单,不然就觉得自己亏了。"这不就是典型的"班味入侵"吗?工作思维已经渗透到生活的方方面面。
小型域名服务器:啊?我一直都这样啊?我还以为是我爱贪小便宜呢?每次去实验室都得接一杯免费的开水回去,出门都得规划一下最短路径,在宿舍就吃南边的食堂,在实验室就吃北边的食堂,快递只有顺路的时候才取。
点赞 评论 收藏
分享
offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
有趣的牛油果开挂了:最近这个阶段收到些杂七杂八的短信是真的烦
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务