JAVA_数组中任意个数元素之和等于一个数

时间:2019-06-18
本文章向大家介绍JAVA_数组中任意个数元素之和等于一个数,主要包括JAVA_数组中任意个数元素之和等于一个数使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

java数组中任意元素之和等于一个数的所有可能结果

public static void main(String[] args) {
double[] taDous ={50000.0,60000.0,100000.0,40000.0,30000.0,80000.0,10000.0,10000.0,20000.0,30000.0,30000.0};

diguiSum(taDous,100000.0);
double sum = 35.0;
}
public double[] diguiSum(double[] array,double sum) {
for (int i = 0; i < array.length; i++) {
double[] cache = new double[i + 1];
int ceng = -1;
int cengQuit = i;
int startPiont = 0;
double[] cir = cir(ceng, cengQuit, startPiont, array, cache, sum);
return cir;
}
return null;
}

// 递归求结果
public double[] cir(int ceng, int cengQuit, int startPiont, double[] array, double[] cache, double sum) {
ceng++;
for (int i = startPiont; i < array.length; i++) {
cache[ceng] = array[i];
if (ceng == cengQuit) {
if (getSum(cache) == sum) {
printcache(cache);
//return cache;
}
if (getSum(cache) > sum) {
break;
}
}
if (ceng < cengQuit) {
startPiont = i + 1;
cir(ceng, cengQuit, startPiont, array, cache,sum);
}
}
return null;
}

// 获取组合数字之和
public double getSum(double[] cache) {
double sum = 0.0;
for (int i = 0; i < cache.length; i++) {
sum = sum + cache[i];
}
return sum;
}

// 打印组合的可能
public void printcache(double[] cache) {
for (int i = 0; i < cache.length; i++) {
System.out.print(cache[i] + ",");
}
System.out.println();
}

原文地址:https://www.cnblogs.com/foolfishs/p/java_sum.html