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();
}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM