如何创建一个包含整数数组的方法,然后允许该特定方法在从主类调用该方法时打印该数组的所有元素?
这是我做的一个程序作为例子:
我试图找到int
输入的所有可能因素。我使用了一个名为generateFactors()
的方法来存储数字的所有可能因子,但由于某种原因我无法打印数组元素。在toString()
方法中,出现错误void type not allowed here
!
public class FactorNumbers {
private int number;
public FactorNumbers(int number) {
this.number = number;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
public void generateFactors() {
int[] factors = new int[number];
for (int i = 0; i < number; i++) {
if ((i + 1 % number) == 0) {
factors[i] = i;
System.out.println("Factor= " + i);
} else {
factors[i] = 0;
}
}
for (int i = 0; i < number; i++) {
System.out.println(factors[i] + "");
}
}
@Override
public String toString() {
return "The factors of " + number + "are: " + generateFactors();
}
}
答案 0 :(得分:4)
为了做你想做的事,代码必须如下所示:
public String generateFactors() {
String ret = "";
int[] factors = new int[number];
for (int i = 0; i < number; i++) {
if ((i + 1 % number) == 0) {
factors[i] = i;
ret += "Factor= " + i + "\n";
} else {
factors[i] = 0;
}
}
for (int i = 0; i < number; i++) {
ret += factors[i] + "\n";
}
return ret;
}
但是,你的代码不会返回因素,我认为你真正想做的是这样的事情:
public String generateFactors() {
String ret = "";
int[] factors = new int[number];
for (int i = 0; i < number; i++) {
//The remainder needs to be reversed
if ((number % (i + 1)) == 0) {
factors[i] = i+1;
} else {
factors[i] = 0;
}
}
for (int i = 0; i < number; i++) {
//only print them if they are a factor
if(factors[i] != 0)
ret += factors[i] + "\n";
}
return ret;
}
答案 1 :(得分:0)
toString()方法不适用于数组,并且使用 void 作为返回的方法。而是使用 Arrays.toString(array):
public static void main(String[] args) {
FactorNumbers fn = new FactorNumbers(100);
int[] factors = fn.generateFactors();
System.out.println(Arrays.toString(factors));
}
在主方法中打印数组中包含的所有值,并将 generateFactors()方法重构为:
public int[] generateFactors() {
int[] factors = new int[number];
for (int i = 0; i < number; i++) {
if ((i + 1 % number) == 0) {
factors[i] = i;
System.out.println("Factor= " + i);
} else {
factors[i] = 0;
}
}
return factors;
}
注意: 但是,您的代码不会给您任何因素,因为:
if ((i + 1 % number) == 0)
将始终返回false。替换为:
if((number % i+1) == 0)
获得正确的输出。
答案 2 :(得分:0)
更改您的方法如下: 如果需要,您可以使用stringbuilder。
public String generateFactors() {
int[] factors = new int[number];
String strPrint = "";
for (int i = 0; i < number; i++) {
if ((i + 1 % number) == 0) {
factors[i] = i;
strPrint = strPrint + "Factor= " + i + "\n"
//System.out.println("Factor= " + i);
} else {
factors[i] = 0;
}
}
for (int i = 0; i < number; i++) {
strPrint = strPrint + factors[i] + "\n"
// System.out.println(factors[i] + "");
}
return strPrint;
}