题解 | #数组分组#

数组分组

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);
    }
}
全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务