結果

提出番号 1421
提出者 olphe
言語 C++
提出日時 2018-08-02 22:00:28
問題名 (71)音楽ゲーム
結果 AC
点数 100%

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 AC 100% 16ms 10640KB
2 AC 100% 10ms 8528KB
3 AC 100% 11ms 8528KB
4 AC 100% 26ms 14864KB
5 AC 100% 20ms 12752KB
6 AC 100% 25ms 14864KB
7 AC 100% 3ms 8064KB
8 AC 100% 29ms 14864KB
9 AC 100% 40ms 18032KB
10 AC 100% 27ms 14864KB
11 AC 100% 28ms 15920KB
12 AC 100% 51ms 20144KB
13 AC 100% 13ms 10640KB
14 AC 100% 43ms 19088KB
15 AC 100% 9ms 8800KB
16 AC 100% 4ms 8144KB
17 AC 100% 58ms 21200KB
18 AC 100% 37ms 18032KB
19 AC 100% 18ms 11696KB
20 AC 100% 30ms 15920KB
21 AC 100% 50ms 21200KB
22 AC 100% 51ms 20144KB
23 AC 100% 53ms 21200KB
24 AC 100% 3ms 7824KB
25 AC 100% 51ms 20144KB
26 AC 100% 51ms 21200KB
27 AC 100% 23ms 12848KB
28 AC 100% 58ms 22256KB
29 AC 100% 35ms 16976KB
30 AC 100% 48ms 20144KB

ソースコード

#include "iostream"
#include "climits"
#include "list"
#include "queue"
#include "stack"
#include "set"
#include "functional"
#include "algorithm"
#include "string"
#include "map"
#include "unordered_map"
#include "unordered_set"
#include "iomanip"
#include "cmath"
#include "random"
#include "bitset"
#include "cstdio"

using namespace std;

const long long int MOD = 1000000007;
const long double EPS = 1e-8;

long long int N, M, K, H, W, L, R;

int main() {
	ios::sync_with_stdio(false);
	cin.tie(0);

	cin >> N;
	vector<int>v(N);
	for (int i = 0; i < N; i++)cin >> v[i];
	sort(v.begin(), v.end());
	long long int add = 1;
	int bef = *v.begin();
	map<int, long long int>m;
	for (auto i : v) {
		if (i != bef) {
			if (bef == *v.begin()) {
				add = m[bef];
			}
			else {
				add += m[bef];
			}
			add %= MOD;
			m[i] += add;
			m[i] %= MOD;
			bef = i;
		}
		else {
			m[i] += add;
			m[i] %= MOD;
		}
	}
	long long int ans = 0;
	for (auto i : m) {
		ans += i.second;
		ans %= MOD;
	}
	cout << ans << endl;
	return 0;
}