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

题目:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值