我的任务是创建一个方法,该方法将接受用户输入的3位数int并输出其倒数(123-321)。我不允许将int转换为字符串,否则会丢失点,也不允许在main以外的任何位置进行打印。
public class Lab01
{
public int sumTheDigits(int num)
{
int sum = 0;
while(num > 0)
{
sum = sum + num % 10;
num = num/10;
}
return sum;
}
public int reverseTheOrder(int reverse)
{
return reverse;
}
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
Lab01 lab = new Lab01();
System.out.println("Enter a three digit number: ");
int theNum = input.nextInt();
int theSum = lab.sumTheDigits(theNum);
int theReverse = lab.reverseTheOrder(theSum);
System.out.println("The sum of the digits of " + theNum + " is " + theSum);
}
答案 0 :(得分:0)
您需要使用以下内容。
%
余数运算符/
除法运算符*
乘法。+
添加Say you have a number 987
n = 987
r = n % 10 = 7 remainder when dividing by 10
n = n/10 = 98 integer division
Now repeat with n until n = 0, keeping track of r.
一旦您了解了这一点,就可以进行实验(也许先在纸上进行),看看如何 将它们放回相反的顺序(使用最后两个运算符)。但是请记住,以0结尾(如980)的数字将变为89,因为前导0被删除了。
答案 1 :(得分:-2)
您可以使用以下方法计算数字的倒数。
public int reverseTheOrder(int reverse){
int result = 0;
while(reverse != 0){
int rem = reverse%10;
result = (result *10) + rem;
reverse /= 10;
}
return result;
}