結果

提出番号 1420
提出者 olphe
言語 C++
提出日時 2018-08-02 21:58:21
問題名 (71)音楽ゲーム
結果 WA
点数 0%

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 WA 0% 17ms 10640KB
2 WA 0% 11ms 8528KB
3 WA 0% 11ms 8528KB
4 WA 0% 27ms 14864KB
5 WA 0% 19ms 12752KB
6 WA 0% 27ms 14864KB
7 WA 0% 2ms 8256KB
8 WA 0% 28ms 14864KB
9 WA 0% 43ms 18032KB
10 WA 0% 27ms 14864KB
11 WA 0% 30ms 15920KB
12 WA 0% 54ms 20144KB
13 WA 0% 16ms 10640KB
14 WA 0% 41ms 19088KB
15 WA 0% 9ms 8800KB
16 WA 0% 4ms 8576KB
17 WA 0% 57ms 21200KB
18 WA 0% 39ms 18032KB
19 WA 0% 16ms 11696KB
20 WA 0% 30ms 15920KB
21 WA 0% 60ms 21200KB
22 WA 0% 49ms 20144KB
23 WA 0% 48ms 21200KB
24 WA 0% 2ms 8704KB
25 WA 0% 51ms 20144KB
26 WA 0% 51ms 21200KB
27 WA 0% 21ms 12864KB
28 WA 0% 56ms 22256KB
29 WA 0% 35ms 16976KB
30 WA 0% 51ms 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];
			}
			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;
}