如何在不将int转换为字符串的情况下反转其顺序



我的任务是创建一个方法,该方法将接受用户输入的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);
}

您需要使用以下内容。

  • %余数运算符
  • /除法运算符
  • CCD_ 3乘法
  • +添加
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这样以0结尾的数字将变成89。

您可以使用以下方法来计算一个数的倒数。

public int reverseTheOrder(int reverse){
int result = 0;
while(reverse != 0){
int rem = reverse%10;
result = (result *10) + rem;
reverse /= 10;
}
return result;
}

相关内容

  • 没有找到相关文章

最新更新