結果

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

テストケース

テストケース 結果 得点 実行時間 メモリ使用量
1 WA 0% 15ms 10640KB
2 WA 0% 11ms 8720KB
3 WA 0% 12ms 8528KB
4 WA 0% 28ms 14864KB
5 WA 0% 23ms 12752KB
6 WA 0% 27ms 14864KB
7 WA 0% 3ms 8064KB
8 WA 0% 30ms 14864KB
9 WA 0% 42ms 18032KB
10 WA 0% 26ms 14864KB
11 WA 0% 33ms 15920KB
12 WA 0% 51ms 20144KB
13 WA 0% 15ms 10640KB
14 WA 0% 42ms 19088KB
15 WA 0% 10ms 8800KB
16 WA 0% 4ms 7776KB
17 WA 0% 54ms 21200KB
18 WA 0% 41ms 18032KB
19 WA 0% 16ms 11696KB
20 WA 0% 36ms 15920KB
21 WA 0% 59ms 21200KB
22 WA 0% 51ms 20144KB
23 WA 0% 62ms 21200KB
24 WA 0% 3ms 8064KB
25 WA 0% 50ms 20144KB
26 WA 0% 56ms 21200KB
27 WA 0% 24ms 12880KB
28 WA 0% 62ms 22256KB
29 WA 0% 33ms 16976KB
30 WA 0% 58ms 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 = -1;
	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;
}