麒麟zero 2013-09-16 06:59 采纳率: 100%
浏览 2325
已采纳

Java高要求逻辑训练题

给定等式其中每个字母代表一个数字,且不同数字对应不同字母。编程求出这些数字并且打出这个数字的算术计算竖式。

   A B C D E
  +    D F G
  +    D F G
——————————
   X Y Z D E

ABCDEFGXYZ十个字母各不相等并且分别代表0~9
试过用for循环遍历,但是判断条件想得头都大了。同时经常漏掉判断条件得出很多个错误答案
试过用数组代表0~9先求出算数式再代入字母,依然不知从何下手
也试过先找出隐性条件例G==0 F==5 X==A+1 B>=8 但是想得还是头大。
求:
解这个题目是否需要用到算法?
尽量简短的实现代码

万分感谢~~~

  • 写回答

1条回答 默认 最新

  • wangqingchengsg 2013-11-07 17:53
    关注

    package test;

    import java.util.Arrays;
    import java.util.HashMap;
    import java.util.Map;

    public class Test {

    /**
     * @param args
     */
    private static Map<String, Integer> map = new HashMap<String, Integer>();
    private static Map<String, String> maps = new HashMap<String, String>();
    
    static {
        for (int i = 0; i < 10; i++) {
            byte[] bytes = { (byte) (97 + i) };
            map.put(new String(bytes).toUpperCase(), i);
            maps.put(i+"", new String(bytes).toUpperCase());
        }
        maps.put(" ", " ");
        maps.put("+", "+");
    }
    
    public static Long[] strToLong(String[] ag) {
        Long[] lo = new Long[ag.length + 1];
        Long res = 0L;
        for (int i = 0; i < ag.length; i++) {
            char[] ch = ag[i].toCharArray();
            String str = "";
            for (int j = 0; j < ch.length; j++) {
                str = str + map.get(String.valueOf(ch[j])) + "";
            }
    
            lo[i] = Long.valueOf(str);
            res += lo[i];
        }
        lo[lo.length - 1] = res;
        Arrays.sort(lo);
    
        return lo;
    }
    
    public static String[] maxLong(Long[] str) {
        String[] rest = new String[str.length];
        long maxLen = str[str.length - 1].toString().length();
    
        for (int i = 0; i < str.length; i++) {
            long Len = str[i].toString().length();
            long sub = maxLen - Len;
            String s = "";
            for (int j = 0; j < sub; j++) {
                s = " " + s;
            }
    
            s = s + str[i];
                rest[i] = s;
    
        }
    
        return rest;
    }
    
    public static void main(String[] args) {
        String[] ag = { "BAAAA", "BAAA", "BAABB", "BAABB" };
        Long[] lo = strToLong(ag);
        String[] str = maxLong(lo);
        for (int i = 0; i < str.length; i++) {
    
            if (i == 0 || i == str.length - 1 ){
                System.out.print("   ");
            } else {
                System.out.print("+  ");
            }
    
            char[] byt = str[i].toCharArray();
            for (int j = 0 ; j < byt.length; j++){
                System.out.print(maps.get(byt[j]+""));
            }
    
            System.out.println();
    
            if (str.length - 2 == i){
                System.out.println("-------------");
            } 
    
    
            //System.out.println(str[i]);
        }
    }
    

    }

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 雄安新区高光谱数据集的下载网址打不开
  • ¥66 android运行时native和graphics内存详细信息获取
  • ¥100 求一个c#通过CH341读取数据的Demo,能够读取指定地址值的功能
  • ¥15 rk3566 Android11 USB摄像头 微信
  • ¥15 torch框架下的强化学习DQN训练奖励值浮动过低,希望指导如何调整
  • ¥35 西门子博图v16安装密钥提示CryptAcquireContext MS_DEF_PROV Error of containger opening
  • ¥15 mes系统扫码追溯功能
  • ¥40 selenium访问信用中国
  • ¥20 在搭建fabric网络过程中遇到“无法使用新的生命周期”的报错
  • ¥15 Python中关于代码运行报错的问题
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部