(100分)java实现一个简单的算法:从一个数组中,取N个数总和等于M正负10% 的 这个 N个数

聂鹏 2009-05-16 01:30:17
有这样一个int[] a数组: 里面的数都是10 到 70 之间的 数,随机分配的不确定,但这个数组大约有80个数
实现这样一个算法: 从这个数组中取 n个数, 使其 总和total, m* 0.9 <= total <= m*1.1 ,
满足上面要求的 实现某一个种就可以(如果可以多次执行的效果不同)
其中N肯定小于 数组的大小 方法返回的是原始数组的下标的 新数组(如果这样不行,那返回n个数 的数组)

public int[] getNewInts(int n, int m ,int [] a){
return null;
}
...全文
807 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
izard999 2009-05-17
  • 打赏
  • 举报
回复
还是不明白LZ的这个m是什么意思
izard999 2009-05-17
  • 打赏
  • 举报
回复
先mark下.看题去,
nishiyitouniu 2009-05-17
  • 打赏
  • 举报
回复
up 学习
SimonYeung 2009-05-16
  • 打赏
  • 举报
回复
MARK 学习
lulu0126 2009-05-16
  • 打赏
  • 举报
回复
没有搞懂m,n

先mark一下!
wcwtitxu 2009-05-16
  • 打赏
  • 举报
回复
这个算法一点都不简单
wanyuzhen 2009-05-16
  • 打赏
  • 举报
回复
背包问题,简化就可以
xnjnmn 2009-05-16
  • 打赏
  • 举报
回复

package com;

public class getNew {
/*
* 有这样一个int[] a数组: 里面的数都是10 到 70 之间的 数,随机分配的不确定,但这个数组大约有80个数 实现这样一个算法:
* 从这个数组中取 n个数, 使其 总和total, m* 0.9 <= total <= m*1.1 , 满足上面要求的
* 实现某一个种就可以(如果可以多次执行的效果不同) 其中N肯定小于 数组的大小 方法返回的是原始数组的下标的 新数组(如果这样不行,那返回n个数
* 的数组)
*/

/**
* int[] a数组: 里面的数都是10 到 70 之间的 数,随机分配的不确定,但这个数组大约有80个数 数组范围a,start10
* b,end70 c,数组大小80
*/
public static int[] getInt(int a, int b, int c) {
// 但这个数组大约有80个数
int[] data = new int[c];

for (int i = 0; i < data.length; i++) {
// 10 到 70 之间的 数,随机分配的不确定
int index = (int) Math.floor(Math.random() * (b-a))+a;
data[i] = index;
}
return data;
}
//test
/*public static void main(String[] arg){
int b[] = getInt(10,70,80);
for(int i = 0;i<b.length;i++){

System.out.println(b[i]);
}
}*/

public static void main(String[] arg){
//里面的数都是10 到 70 之间的 数,随机分配的不确定,但这个数组大约有80个数
int b[] = getInt(10,70,80);int m =0;
//从这个数组中取 n个数, 使其 总和total
int n = 1;
System.out.println("total----"+getNewInts(b,n,m));
System.out.println("total----"+getNewInts(b,10,m));
System.out.println("total----"+getNewInts(b,20,m));
System.out.println("total----"+getNewInts(b,30,m));
System.out.println("total----"+getNewInts(b,60,m));
}

/**
* int[] n 从这个数组中取 n个数
* double total 总和
*/
public static double getNewInts(int[] data,int n, int m){
double total =0;
//从这个数组中取 n个数
int[] getn =new int[n];
for (int i = 0; i < n; i++) {
//这个数组中取 n个数---随机
int index = (int) Math.floor(Math.random() *n);
getn[i] = data[index];
}
//total 总和
for (int i = 0; i < n; i++){

total=total+getn[i];
}
/*//m* 0.9 <= total <= m*1.1 , 满足上面要求的 不知道楼主这里是什么意思
if( m* 0.9 <= total&& total <= m*1.1){


}*/
return total;
}


}




输出:
total----67.0
total----486.0
total----947.0
total----1164.0
total----2406.0
neohope 2009-05-16
  • 打赏
  • 举报
回复
贪婪算法?
knightzhuwei 2009-05-16
  • 打赏
  • 举报
回复
我想说我有一个小小的问题: m是什么?
bcbkill 2009-05-16
  • 打赏
  • 举报
回复
我真的看不明!!
gao512008 2009-05-16
  • 打赏
  • 举报
回复
筱伟 2009-05-16
  • 打赏
  • 举报
回复
是啊

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧