题目:
为了得到一个数的"相反数",我们将这个数的数字顺序颠倒,然后再加上原先的数得到"相反数"。例如,为了得到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);
}