java模拟全排列按序输出所有可能的结果

这篇博客记录了一道在线笔试题目,要求使用Java实现全排列并按升序输出所有可能的结果。博主通过问题分析,分解任务为找出所有排序可能性和排序两个步骤。在全排列部分,利用递归思想模拟全排列过程;排序部分则将整数组合成字符串,按字符串排序得到升序结果。最后提供了代码实现。
摘要由CSDN通过智能技术生成

0前言

今天在线笔试遇见了一个很有意思的编程题,特此整理记录如下:

1.问题描述

问题描述(大概意思是)
给出一组整数(整数范围是1-9,数据不重复),要求按升序输出所有的排序可能性

输入:首先输入一个n表示数据个数,然后是n个整数
输出:按升序一次输出每一种结果

例如:

输入 :
3
1 5 9

输出
159
195
519
591
915
951

2.问题分析

根据题意不难将问题分解成:

1.找出所有的排序可能性
2.将所有的结果进行排序

2.1 找出所有的排序可能性

所有的排序可能性,即模拟全排列
根据已知知识点,可知所有可能性的个数为:

全排列个数

问题的关键点就在于,如何模拟出所有的可能性

首先,拿例子1 5 9来说

159
195
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值