题解 | #数组分组#

数组分组

http://www.nowcoder.com/practice/9af744a3517440508dbeb297020aca86

1.1 看题目的意思是必须全部分完,后来看题解,应该是只要有满足的就可以

1.2 所用逻辑

计算出所有元素的总和,若这个总和不是2的倍数,就绝对分不了。若可以整除啊,就开始找int target = sum / 2 - sum3;在非 3 5 倍数的数组中有没有一个或多个元素构成。
helper(l + 1, list, target - list.get(l)) 多个元素是否可以构成
helper(l + 1, list, target) 当前元素是否可以构成,只要有一个结果满足就可以
import java.util.*;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int num = in.nextInt();
            // 开始分组,将 3 的倍数和 5 的倍数分开
            int sum3 = 0;
            int sum = 0;
            int sum5 = 0;
            List<Integer> otners = new ArrayList<>();
            for(int i = 0; i < num; i++) {
                int s = in.nextInt();
                sum += s;
                if (s % 3 == 0) {
                    sum3 += s;
                } else if (s % 5 == 0) {
                    sum5 += s;
                } else {
                    // 所有可以拼接的数字
                    otners.add(s);
                }
            }
            // 之后开始判断
            // 1. 如果 sum 本身就没办法平分,那么一定平分不了
            if(sum % 2 != 0) {
                System.out.println("false");
            } else {
                // 2. 不用全部分完,有满足平分即可(个人理解)
                int target = sum / 2 - sum3;
                // 数组中只要存在一个等于 target 或是几个相加等于的就可以返回true
                System.out.println(helper(0, otners, target) + "");
            }
        }
    }
    
    private static boolean helper(int l, List<Integer> list, int target){
        if(l == list.size()) {
            // 比较到数组最后一个,只有 target 为 0 的时候才是 true
            return target == 0;
        }
        // helper(l + 1, list, target - list.get(l)) 将当前元素加到数组中比较必须的
        // helper(l + 1, list, target) 往后比较,不再添加元素到数组
        return helper(l + 1, list, target - list.get(l)) || helper(l + 1, list, target);
    }
}
全部评论

相关推荐

昨天 17:42
酷酷的喜马拉雅山:你为什么发我的offer列表?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 你的mentor是什么样的人? #
3895次浏览 28人参与
# 你觉得mentor喜欢什么样的实习生 #
10253次浏览 284人参与
# 平安产险科技校招 #
2404次浏览 0人参与
# 帮我看看,领导说这话什么意思? #
6110次浏览 25人参与
# 没有家庭托举的我是怎么找工作的 #
12292次浏览 158人参与
# 怎么给家人解释你的工作? #
1371次浏览 16人参与
# 未岚大陆求职进展汇总 #
23818次浏览 112人参与
# 求职低谷期你是怎么度过的 #
5208次浏览 91人参与
# 26届秋招公司红黑榜 #
11934次浏览 41人参与
# 从哪些方向判断这个offer值不值得去? #
6545次浏览 93人参与
# 同bg的你秋招战况如何? #
158817次浏览 927人参与
# 度小满求职进展汇总 #
10078次浏览 51人参与
# 实习必须要去大厂吗? #
146625次浏览 1541人参与
# 校招泡的最久的公司是哪家? #
4531次浏览 22人参与
# 你有哪些缓解焦虑的方法? #
37173次浏览 835人参与
# 面试紧张时你会有什么表现? #
1694次浏览 20人参与
# 你喜欢工作还是上学 #
77572次浏览 860人参与
# 入职第一天,你准备什么时候下班 #
85471次浏览 467人参与
# 秋招想进国企该如何准备 #
97706次浏览 487人参与
# 简历无回复,你会继续海投还是优化再投? #
103582次浏览 819人参与
# 机械人的工作环境真的很差吗 #
25014次浏览 119人参与
# 独居后,你的生活是更好了还是更差了? #
28125次浏览 263人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务