A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© ssy1939 中级黑马   /  2014-8-7 15:17  /  1512 人查看  /  10 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

从键盘录入一个整数, 计算这个数有多少中方法可以得出,并打印出 具体的方法
如 1=1  一种;2 =1+1 一种; 3 =1+2 ,3=2+1, 3 = 1+1+1 三种;4 =1+3,4=2+2, 4 = 3+1; 4 =1+1+1+1 四种;  等

10 个回复

倒序浏览
4=1+1+1+1
4=1+1+2
4=1+2+1
4=2+1+1
4=2+2
4=1+3
4=3+1

这是好多种啊
回复 使用道具 举报
这有什么意义吗
回复 使用道具 举报
杨庆雷 发表于 2014-8-7 15:26
4=1+1+1+1
4=1+1+2
4=1+2+1

我貌似少写了,有代码吗?
回复 使用道具 举报
本帖最后由 曾宇 于 2014-8-7 17:24 编辑

这是你要的代码:
  1. class  AddDemo
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 add(9);
  6.         }
  7.         public static void add(int num){
  8.                 StringBuilder sbd = new StringBuilder(num+"=1");
  9.                 for(int s=1;s<num;s++){
  10.                         sbd.append("+1");
  11.                 }
  12.                 System.out.println(sbd);
  13.                 for(int i=1;i<num;i++){
  14.                         for(int j = num-1;j>0;j--){
  15.                                 if((i+j)==num){
  16.                                         System.out.println(num+"="+i+"+"+j);
  17.                                 }
  18.                                
  19.                         }
  20.                 }
  21.         }
  22. }
复制代码



回复 使用道具 举报
递归
  1. import java.util.ArrayList;

  2. /**
  3. * 给定一个正整数,输出有多少种加法方式可以得到这个数,例如
  4. * 4=1+1+1+1
  5. * 4=1+1+2
  6. * 4=1+2+1
  7. * 4=2+1+1
  8. * 4=2+2
  9. * 4=1+3
  10. * 4=3+1
  11. * @author think
  12. *
  13. */

  14. public class AddDecomposition {

  15.         public static void main(String[] args) {
  16.                 decompose(4);
  17.         }

  18.         private static void decompose(int n) {
  19.                 if (n == 1)
  20.                         System.out.println("1=1");
  21.                 else {
  22.                         ArrayList<Integer> adders = new ArrayList<Integer>(); // 存放最初的数和分解出来的加数
  23.                         adders.add(n);
  24.                         executeDecomposition(n, adders);
  25.                 }
  26.         }

  27.         private static void executeDecomposition(int n, ArrayList<Integer> adders) {
  28.                 // 分解完毕,打印结果
  29.                 if (n == 0) {
  30.                         int adderNum = adders.size();
  31.                         System.out.print(adders.get(0) + "=");
  32.                         for (int i = 1; i < adderNum; i++) {
  33.                                 if (i == adderNum - 1)
  34.                                         System.out.println(adders.get(i));
  35.                                 else
  36.                                         System.out.print(adders.get(i) + "+");
  37.                         }
  38.                         return;
  39.                 }
  40.                
  41.                
  42.                 // 加数取值范围:1到n
  43.                 for (int i = 1; i <= n; i++) {
  44.                         if (i == adders.get(0)) // 跳过n = 0 + n的情形
  45.                                 break;
  46.                         adders.add(i); // 将i放入加数集合中
  47.                         executeDecomposition(n - i, adders); // 继续寻找加数
  48.                         adders.remove(adders.size() - 1); // 将i从加数集合中删除,尝试下一个i
  49.                 }
  50.         }
  51. }
复制代码
回复 使用道具 举报 1 0
曾宇 发表于 2014-8-7 17:13
这是你要的代码:

你是用什么软件写的?Eclipse?
回复 使用道具 举报
  1. class FunctionDemo2 {
  2.         public static void main(String[] args) {
  3.                 int i = 6;                //需要拆分的数
  4.                 List<String> li = numSplit(6);
  5.                 for(String s : li) {
  6.                         System.out.println(s);
  7.                 }
  8.         }
  9.        
  10.         /*
  11.          * 一个整数n的所有不同拆分,等于:
  12.          * 1 + (n-1的所有拆分)
  13.          * 2 + (n-2的所有拆分)
  14.          * .....
  15.          * n-2 + (2的所有拆分)
  16.          * n-1 + (1)
  17.          *
  18.          * 因此,用递归做
  19.          */
  20.        
  21.         //numSplit方法中,放入n,将返回一个n的不同拆分的String集合
  22.         static ArrayList<String> numSplit(int n) {
  23.                 ArrayList<String> li = new ArrayList<String>();
  24.                 ArrayList<String> lin_1 = null;
  25.                 if(n==1){
  26.                         li.add("1");
  27.                         return li;
  28.                 }
  29.                 for(int i=1; i<n; i++) {
  30.                         lin_1 = numSplit(n-i);                //递归,返回n-i的拆分集合
  31.                         for(String s : lin_1) {
  32.                                 li.add(i+"+"+s);                //把n-i的拆分挨个连接"i",装入n的拆分集合
  33.                         }
  34.                 }
  35.                 li.add(""+n);
  36.                 return li;
  37.         }
  38. }

  39. /* 没有做去重,如果考虑1+1+2、1+2+1、2+1+1为重复,需要去重,可以考虑:
  40. * 把每个拆分字符串拆解为int数组,排序,然后比较去重。
  41. */
复制代码
回复 使用道具 举报
真不觉得有什么意义呀!

点评

很多算法看上去是没有意义的 只是看上去  发表于 2014-8-8 07:58
回复 使用道具 举报
wawsc5354524 发表于 2014-8-8 02:11
你是用什么软件写的?Eclipse?

Edit plus3
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马