当前位置:   article > 正文

【期中考试-整数反转】_给出一个32位的有符号整数n,请将该数进行反转(正负符号不变,其余数字反转)。 反转

给出一个32位的有符号整数n,请将该数进行反转(正负符号不变,其余数字反转)。 反转

【问题描述】

        给出一个32位的有符号整数n,请将该数进行反转(正负符号不变,其余数字反转)。

        反转后的数如果溢出,则输出0。

【输入形式】

        输入为一行一个整数
【输出形式】

        输出为一行一个整数
【样例输入1】

123

【样例输出1】

321

【样例输入2】

-123

【样例输出2】

-321

【样例说明】

       32位有符号整形的取值范围为-2147483648~2147483647

【说明】数据溢出的判断

  1. #include <iostream>
  2. using namespace std;
  3. int main()
  4. {
  5. long int n,k=0;
  6. cin>>n;
  7. if(n>=0)
  8. {
  9. while(n>0)
  10. {
  11. if((k*10+n%10)>=214728365&&n>1)
  12. {
  13. k=0;
  14. break;
  15. }
  16. else
  17. {
  18. k=k*10+n%10;
  19. n=n/10;
  20. }
  21. }
  22. cout<<k;
  23. }
  24. else
  25. {
  26. n=-n;
  27. while(n>0)
  28. {
  29. if((k*10+n%10)>=214728365&&n>1)
  30. {
  31. k=0;
  32. break;
  33. }
  34. else
  35. {
  36. k=k*10+n%10;
  37. n=n/10;
  38. }
  39. }
  40. k=-k;
  41. cout<<k;
  42. }
  43. return 0;
  44. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/算法编织者/article/detail/60475
推荐阅读
相关标签
  

闽ICP备14008679号