【编程题】数字黑洞

  附上Java实现代码。

 1 package NetEasy;
 2 
 3 /**
 4  * 数字黑洞
 5  */
 6 
 7 import java.util.Scanner;
 8 
 9 public class NumBlackHole {
10 
11     public static void main(String[] args) {
12         Scanner in = new Scanner(System.in);
13         String number = in.next();
14 //        StringBuffer numStr = new StringBuffer();
15 //        numStr.append(number);
16         if(number.charAt(0)==number.charAt(1) &&
17                 number.charAt(0)==number.charAt(2)&&
18                 number.charAt(0)==number.charAt(3))
19             System.out.println(number+" - "+number+" = 0");
20         else{
21             boolean flag = true;
22 //            int num = Integer.valueOf(number);
23             while(flag){
24                 number = computeNum(number);
25                 if(number.equals("6174"))
26                     flag = false;
27             }
28         }
29 
30     }
31 
32     private static String computeNum(String number) {
33 //        String number = Integer.valueOf(num).toString();
34         StringBuffer numOrder = new StringBuffer(number);
35         for(int i = 0; i < 4; i++){
36             for(int j = i; j < 4; j++){
37                 if(numOrder.charAt(i) < numOrder.charAt(j)){
38                     char temp = numOrder.charAt(i);
39                     numOrder.setCharAt(i, number.charAt(j));
40                     numOrder.setCharAt(j, temp);
41                 }
42             }
43         }
44 //        StringBuffer numUpper = numOrder;  //这样复制,后面numOrder反转了 numUpper会跟着变化
45         String numUpper = numOrder.toString();
46         String numLower = numOrder.reverse().toString();
47         int n = Integer.valueOf(numUpper)-Integer.valueOf(numLower);
48         StringBuffer result = new StringBuffer(Integer.valueOf(n).toString());
49         if(result.length() == 1)
50             result.insert(0, "000");
51         if(result.length() == 2)
52             result.insert(0, "00");
53         if(result.length() == 3)
54             result.insert(0, "0");
55         String resultnum = result.toString();
56         System.out.println(numUpper+" - "+numLower+" = "+ resultnum);
57         return resultnum;
58     }
59 
60 }

 

转载于:https://www.cnblogs.com/focusonepoint/p/5743123.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值