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

时间:2020-03-20 00:41:55

标签: java reverse dereference

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

2 个答案:

答案 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;
   }