java 数字组合_java解决数字组合问题

问题描述:输入1~9以内的几个数字,输出这些数字的多重组合。

输入:1,2,3

输出:

1

2

3

12

13

23

123

问题分析:

当输入为

1

输出

1

当输入为

1  2

输出

1

2

12

当输入为

1  2  3

输出

1

2

3

12

13

23

123

那么可以分析如下

当输入1 2 3 4时做了以下处理

把上面结果拷贝

1

2

3

12

13

23

123

1

2

3

12

13

23

123

然后在上面的基础上加上4即结果为

1

2

3

12

13

23

123

1

2

3

12

13

23

123

4

然后接着在拷贝的后面部分加上4,结果为

1

2

3

12

13

23

123

14

24

34

124

134

234

1234

4

然后讲以上数字排序输出,就得到了输入为[1 2 3 4] 时的结果。

在这个思路的基础上可以想到用递归的方法来做只需要在上一步的基础之上加上新的数字即可。实现代码如下:

import java.util.ArrayList;

import java.util.Collections;

public class Number {

/*

* 递归函数的输入函数有两个,第一个表示输入数组中第几个数字,第二个表示输入数组

* 由于动态数组可以灵活添加元素,因此使用了动态数组来存储结果

*/

public static ArrayList foo(int i,int[]vec){

//递归结束的条件是读到第一个元素之后返回该元素

if(i==0){

ArrayList list = new ArrayList();

list.add(vec[0]);

return list;

}

else{

//得到上一步的结果

ArrayList nlist = foo(i-1,vec);

int n = nlist.size();

int num = vec[i];

//把输入数组中此处的元素添加进动态数组

nlist.add(num);

//动态数组中的每一个元素将输入数组中当前元素放在个位之后追加到动态数组

for(int k=0;k

nlist.add(nlist.get(k)*10+num);

}

return nlist;

}

}

public static void main(String[] args) {

int[] vec = {1,2,3};

int l = vec.length;

ArrayList list = foo(l-1,vec);

Collections.sort(list);

for(int i:list){

System.out.println(i);

}

}

}

以上是我的解题思路,希望多多指教。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/557846.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iis php的mime映射_iis MIME 映射添加.php文件映射类型肿么定义

进入控制面板,选择程序和功能,打开或关闭Windows 功能,找到Internet informationservices,分别开启FTP服务器、Web管理工具和万维网服务组件,其中万维网服务的子组件也依次开启,”其中最重要的开启应用程序…

usd php 换算,货币在PHP中从INR转换为USD

我想在PHP中将货币从INR转换为USD,这是我迄今为止尝试过的代码.但它不起作用.我错过了什么?function currency($from_Currency,$to_Currency,$amount) {$amount urlencode($amount);$from_Currency urlencode($from_Currency);$to_Currency urlencode($to_Curren…

Node.js介绍、优势、用途

一、Node.js介绍 Node.js是一个javascript运行环境。它让javascript可以开发后端程序,实现几乎其他后端语言实现的所有功能,可以与PHP、Java、Python、.NET、Ruby等后端语言平起平坐。 Nodejs是基于V8引擎,V8是Google发布的开源JavaScript引…

php数组有没有类似next方法,PHP 数组current跟next用法

PHP 数组current和next用法1.current$transport array(foot, bike, car, plane);$mode current($transport); //$mode foot;$mode next($transport); // $modebike;$mode current($transport); //$mode bike;$mode prev($transport); // $mode foot;$mode end($trans…

RROR in main Module not found: Error: Can‘t resolve ‘index.js‘

第一种方式,使用新的命令 webpack打包的时候报错 webpack版本升级了 这个命令不能用了 用这个就可以: webpack ./index.js -o ./dist./dist是打包文件生成的目录 另一种方式 更改webpack版本,降低版本,还有webpak这个命令 降…

swfupload 实例 php,文件上传之SWFUpload插件(代码)

下面通过一段代码给大家演示下,主要分为1.前台文件index.html和 2.后台文件upload.php。具体代码如下所示:1.前台文件index.htmlSWFUploadvar swfu;window.onload function() {var settings {flash_url : "swfupload/swfupload.swf",upload_…

Vue报错:Unknown custom element: router-view - did you register the component correctly页面中不显示链接

Vue报错:Unknown custom element: router-view - did you register the component correctly vue-router应用到组件中时报错: Unknown custom element: - did you register the component correctly? For recursive components, make sure to provide t…

java 中 的 =,java 中的 |=、=、^=

关于 | 运算符:| 运算符和 这一类的运算符一样,拆解开就是 a a | bint a 5; // 0000 0101int b 3; // 0000 0011a | b; // 0000 00111具体规则为:两个二进制对应位为0时该位为0,否则为1。拿5的二进制 0000 0101 和 3的二进制 …

Vue页面跳转后不显示问题

Vue页面跳转后不显示问题 必须要添加 path前面要有/

HDFS剩余空间大小的Java接口,java api获取hdfs索引大小

java api获取hdfs目录大小1. hadoop fs -dus 的源码:public static void dus(String src,Configuration conf) throws IOException {Path srcPath new Path(src);FileSystem srcFs srcPath.getFileSystem(conf);FileStatus status[] srcFs.globStatus(new Path(s…

Windows之node.js安装

Windows之node.js安装 1.下载node.js, 下载地址:https://nodejs.org/zh-cn/download/ 选择windows安装 2.安装,双击软件图标——接受协议——选择安装路径——选择安装配置(如下图)——等待安装——完成安装。 自动帮…

php开发工具 debug,php开发性能调试工具xdebug

调试是一门艺术,在项目开发过程中,调试是很关键的一步。php中一般使用die,exit()控制断点并使用echo、print_r()、var_dump()、printf()输出结果来调试。一般情况下以上就可以满足开发者调试的目的了。下面来介绍一下xdebug工具。Xdebug是一个开放源代码…

Windows之vue-cli安装和vue项目快速搭建

Windows之vue-cli安装和vue项目快速搭建 1.提前安装好node.js, 安装步骤:https://blog.csdn.net/qq_43842093/article/details/116918715 2.nodejs安装好后,默认带有npm 3.使用npm安装vue-cli cnpm instal1 vue-cli-g #测试是否安装成功#查看…

java 字符流 utf8,JAVA基础(字符流设置编码读写字符)

1,使用指定的码表读写字符FileReader是使用默认码表读取文件, 如果需要使用指定码表读取, 那么可以使用InputStreamReader(字节流,编码表)FileWriter是使用默认码表写出文件, 如果需要使用指定码表写出, 那么可以使用OutputStreamWriter(字节流,编码表)【1】 代码分…

Vue概述和各种前端框架

1、概述 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式JavaScript框架,发布于2014年2月。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,方便与第三方库(如…

Mvvm、第一个Vue程序、Vue基本语法

一、MVVM概述 1.1、什么是MVVM MVVM(Model-View-ViewModel)是一种软件设计模式,由微软WPF(用于替代WinForm,以前就是用这个技术开发桌面应用程序的)和Silverlight(类似于Java Applet&#xff…

matlab中计算不等式的解,matlab解不等式

MATLAB求解非线性规划good (1)_理学_高等教育_教育专区。数学建模课...x4 ? x5 MATLAB 程序如下: f[1; 2; 3; 1; 1]; intcon[1 2 3 4 5]; A[-2 -3 -5 -4 -7; -1 -1 -4 -2 -2]; %改变不等式符号 ......VUB (线性不等式约束) (线性等式约束) (非线性不等式约束) (非线性等式约束…

支付宝沙箱支付步骤

蚂蚁金服开放平台文档中心——网页移动应用——开放能力——支付能力——电脑网站支付下载SDK&Demo调试Demo文档中心——网页移动应用——开发工具——沙箱环境生成公钥和私钥,设置应用公钥在Demo中添加APPID,应用私钥和支付宝公钥支付宝网关

matlab 一维 平滑,一维加噪信号的平滑处理(3)

%-------------------------------------------------------------------------- % 调用medfilt1函数对加噪正弦波信号进行平滑处理 %-------------------------------------------------------------------------- %*****************产生加噪正弦波信号,绘制加噪波…

Module build failed: Error: Node Sass version 5.0.0 is incompatible with ^4.0.0.

Module build failed: Error: Node Sass version 5.0.0 is incompatible with ^4.0.0. node-sass版本过高导致的,卸载重装低版本: 1.卸载已安装版本 npm uninstall node-sass 2.安装 npm install node-sass4.14.1 3.npm run dev