CF1399B.Gifts Fixing

传统题 时间 2000 ms 内存 256 MiB 3 尝试 1 已通过 1 标签

Gifts Fixing

题目描述

你有 nn 份礼物,你想把它们全部送给孩子们。当然,你不想让任何人感到不公平,所以所有礼物应该完全相同。第 ii 份礼物包含 aia_i 颗糖果和 bib_i 个橙子。

每一步操作中,你可以选择某一份礼物 1in1 \le i \le n,并进行以下操作之一:

  • 吃掉这份礼物中的一颗糖果(将 aia_i 减一);
  • 吃掉这份礼物中的一个橙子(将 bib_i 减一);
  • 同时吃掉这份礼物中的一颗糖果和一个橙子(将 aia_ibib_i 都减一)。

当然,如果礼物中没有糖果或橙子,则不能再吃(即 aia_ibib_i 都不能小于零)。

如上所述,所有礼物最终应完全相同。也就是说,经过若干次操作后,需满足以下两个条件:a1=a2==ana_1 = a_2 = \dots = a_nb1=b2==bnb_1 = b_2 = \dots = b_n(但不要求 aia_i 等于 bib_i)。

你的任务是求出使所有礼物相同所需的最少操作次数。

你需要回答 tt 组独立的测试用例。

输入格式

输入的第一行包含一个整数 tt1t10001 \le t \le 1000),表示测试用例的数量。接下来是 tt 组测试用例。

每组测试用例的第一行包含一个整数 nn1n501 \le n \le 50),表示礼物的数量。第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \dots, a_n1ai1091 \le a_i \le 10^9),表示第 ii 份礼物中的糖果数。第三行包含 nn 个整数 b1,b2,,bnb_1, b_2, \dots, b_n1bi1091 \le b_i \le 10^9),表示第 ii 份礼物中的橙子数。

输出格式

对于每组测试用例,输出一个整数,表示使所有礼物相同所需的最少操作次数。

说明/提示

在示例的第一个测试用例中,可以按如下顺序进行操作:

  • 选择第一份礼物,吃掉一个橙子,此时 a=[3,5,6]a = [3, 5, 6]b=[2,2,3]b = [2, 2, 3]
  • 选择第二份礼物,吃掉一个糖果,此时 a=[3,4,6]a = [3, 4, 6]b=[2,2,3]b = [2, 2, 3]
  • 选择第二份礼物,吃掉一个糖果,此时 a=[3,3,6]a = [3, 3, 6]b=[2,2,3]b = [2, 2, 3]
  • 选择第三份礼物,同时吃掉一个糖果和一个橙子,此时 a=[3,3,5]a = [3, 3, 5]b=[2,2,2]b = [2, 2, 2]
  • 选择第三份礼物,吃掉一个糖果,此时 a=[3,3,4]a = [3, 3, 4]b=[2,2,2]b = [2, 2, 2]
  • 选择第三份礼物,吃掉一个糖果,此时 a=[3,3,3]a = [3, 3, 3]b=[2,2,2]b = [2, 2, 2]

由 ChatGPT 4.1 翻译

样例

5
3
3 5 6
3 2 3
5
1 2 3 4 5
5 4 3 2 1
3
1 1 1
2 2 2
6
1 1000000000 1000000000 1000000000 1000000000 1000000000
1 1 1 1 1 1
3
10 12 8
7 5 4
6
16
0
4999999995
7

在线编程 IDE

建议全屏模式获得最佳体验