编程-----相反数求解算法

题目:

为了得到一个数的"相反数",我们将这个数的数字顺序颠倒,然后再加上原先的数得到"相反数"。例如,为了得到1325的"相反数",首先我们将该数的数字顺序颠倒,我们得到5231,之后再加上原先的数,我们得到5231+1325=6556.如果颠倒之后的数字有前缀零,前缀零将会被忽略。例如n = 100, 颠倒之后是1.

输入描述:

输入包括一个整数n,(1 ≤ n ≤ 10^5)

输出描述:

输出一个整数,表示n的相反数

输入例子1:

1325

输出例子1:

6556

JAVA程序实现一:

算法思想:把数字当做字符串处理,调用reverse()方法翻转字符串,再进行加法运算。

import java.util.Scanner;

public class Main {

  public static void main(String[] args) {

       Scanner sc = new Scanner(System.in);

       String s = sc.next();

       System.out.println(Integer.parseInt(new StringBuilder(s).reverse().toString())+Integer.parseInt(s));

       sc.close();

  }

}

JAVA程序实现二:

算法思想:使用对10求余的方法翻转字符串,然后再进行加法运算

import java.util.Scanner;
public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
          int num=in.nextInt();  
          int num1=num;
          int i=0;  
          int sum=0;
          int num2=0;
          String res="";  
          //翻转数字
          while(num!=0){  
              int t1=num%10;  //对10求余获取末位数
              int t2=num/10;  
              res=res+String.valueOf(t1);  
              i++;  
              num=t2;   
          }  
          //将string字符串变成int类型,如string=“123”,变为int a=123.并且自动去前缀0.
          num2=Integer.parseInt(res);
          sum=num1+num2;  //求和
          System.out.println(sum);  
        
    }

你可能感兴趣的:(算法实现,相反数)