AT_arc035_b [ARC035B] アットコーダー王国のコンテスト事情

题目描述

高桥君是 AtCoder 王国的国王。 在他统治的 AtCoder 王国,每年都会举办一次编程竞赛。 在这场竞赛中,会有 $N$ 道题目被出题。此外,排名时有一个要素叫做“罚时”。当你解出某道题时,会根据从比赛开始到解出该题所用的时间,按每题分别计算罚时。所有题目的罚时之和就是本次比赛的总罚时。请注意,这里的罚时规则与 ARC 的罚时不同。 你是一位非常优秀的国民,有能力解出所有题目。而且,你知道每道题需要多少时间才能解出,只要花费恰好这些时间就一定能解出。 你可以以任意顺序解题,请你思考如何解题才能使总罚时最小。 请输出解出所有题目时总罚时的最小值,以及能够达到该最小罚时的解题顺序有多少种。答案对 $1,000,000,007\ (10^9+7)$ 取模。

输入格式

输入通过标准输入给出。 > $N$ > $T_1$ > $T_2$ > $\vdots$ > $T_N$ - 第 $1$ 行是一个整数 $N\ (1\leq N\leq 10,000)$,表示题目数。 - 接下来的 $N$ 行,每行一个整数 $T_i\ (1\leq T_i\leq 10,000)$,表示解第 $i$ 道题所需的时间。

输出格式

请按以下格式输出到标准输出。 - 第 $1$ 行输出总罚时的最小值。注意,32 位整数类型可能会溢出。 - 第 $2$ 行输出能达到最小罚时的解题顺序数,对 $1,000,000,007\ (10^9+7)$ 取模。

说明/提示

## 部分分 本题存在部分分。 - 在 $100$ 分中的 $50$ 分测试点中,能达到最小罚时的解题顺序只有 $1$ 种。 ## 样例解释 1 先解第 $2$ 道题再解第 $1$ 道题是最优的。 - 比赛开始(时刻:$0$ 分)。 - $10$ 分钟后,解出第 $2$ 道题(时刻:$10$ 分),此时罚时为 $10$ 分。 - 再过 $20$ 分钟,解出第 $1$ 道题(时刻:$30$ 分),此时罚时为 $30$ 分。 - 总罚时为 $40(=10+30)$ 分。 ## 样例解释 3 无论以什么顺序解题都可以。不要忘记取模。 由 ChatGPT 4.1 翻译