所以当我编译它时,它说缺少返回需要。
import java.util.*;
class p19
{
public static int isPDA(int n)
{
Scanner ob=new Scanner(System.in);
int i,s=0;
for(i=1;i<n;i++)
{
if(n%i==0)
{
s=s+i;
}
if(s==n)
{
return 0;
}
if(s<n)
{
return -1;
}
if(s>n)
{
return +1;
}
}
}
}
为了扩展@jipr311所说的内容,如果参数"n"是<= 1,那么你永远不会进入for循环,因此永远不会点击其中一个return语句。
为了建立在@jipr311和@DBug所说的基础上,用外行的话来说,编译器需要确保无论条件语句内部发生什么,该方法都会返回一些东西。这意味着在某种程度上,编译器并不关心"if"语句是什么,只是在(如果你的程序设计正确,可能不会发生这种情况)没有执行任何if语句的情况下,将返回一些东西。
正如@DBug所说,解决方法可能是在 if 中添加"else"语句。这向编译器保证,无论哪种方式,"if"条件中的 return 语句或"else"条件中的 return 语句都将执行。您当前的代码不能向编译器保证任何此类事情。
isPDA
是一个方法,无论满足if
中的哪个条件,都必须返回整数,但控制流语句阻止了返回...尝试组织您的想法,尝试如下:
if(s==n)
{
return 0;
}
else if(s<n)
{
return -1;
}
else
{
return +1;
}