个人写的分割正整数方法

 import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class TestSplitInt {

	public static void main(String[] args) {
		Scanner	in=new Scanner(System.in);
		int n;
		
		while((n=in.nextInt())!=-1){
			System.out.println("你选择的是分割:"+n);
			List<String> resultList = split(n);
			
			for (String string : resultList) {
				System.out.println(string);
			}
			System.out.println("答案个数:" + resultList.size());
		}
		in.close();
		
	}

	public static List<String> split(int a) {
		List<String> result = new ArrayList<String>();
		for (int i = a; i > 0; i--) {
			int b = a - i;
			if (b == 0)
				result.add(i + "");
			else if (b <= i)
				result.add(i + "+" + b);
			if (b > 1) {
				List<String> temp = split(b);
				for (int j = 1; j < temp.size(); j++) {
					String s = temp.get(j);
					int m = Integer.parseInt(s.substring(0, s.indexOf("+")));
					if (m <= i)
						result.add(i + "+" + s);
				}
			}
		}
		return result;
	}

}


运行结果示例:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值