📣 VIP通行证夏日特惠 限时立减$68
查看: 1355| 回复: 0
跳转到指定楼层
上一主题 下一主题
收起左侧

交流下additive number

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
一个数字如果能拆成若干组3个数使得前两个数的和为第三个数,些数字称为additive number.
Ex: 123 true, 1234 false, 123246 true, 122436 true.
应该要考虑所有拆分情况,我是直接暴力解了…………求更好的方法

欢迎拍砖……

public static boolean isAdditive(int n){
                if (n<100)
                        return false;
                return isAdditive(String.valueOf(n).toCharArray(),0);
        }
        public static boolean isAdditive(char[] digits, int start){
                int len = digits.length;
                if (start == len)
                        return true;
                if (len - start < 3)
                        return false;
                for (int i = start; i <= start + (len-start)/2; i++){
                        int part1 = charToInt(digits,start,i);
                        int len1 = i - start + 1;
                        for (int j = i+1; j <= i+(len-start)/2; j++){                               
                                int len2 = j - i;
                                int left = len - len1 - len2;
                                if (left < Math.min(len1,len2))
                                        break;
                                int part2 = charToInt(digits,i+1,j);
                                int sum = part1 + part2;
                                int sumLen = String.valueOf(sum).length();
                                if (left >= sumLen){
                                        int part3 = charToInt(digits,j+1,j+sumLen);
                                        if (part3 == sum)
                                                return isAdditive(digits,j+sumLen+1);
                                }
                        }
                }
                return false;                       
        }
       
        public static int charToInt(char[] digits, int start, int end){
                int res = 0;
                for (int i = start; i <= end; i++){
                        res = res * 10 + (digits[i] - '0');
                }
                return res;
        }

上一篇:Check if z can be written as p^q (1 &lt;= z &lt;= 10^9)
下一篇:Nvidia的expo上的一道C++题
您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表