QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#799131#9584. 顾影自怜LyniaAC ✓634ms72484kbC++233.7kb2024-12-04 22:36:502024-12-04 22:36:50

Judging History

你现在查看的是最新测评结果

  • [2024-12-04 22:36:50]
  • 评测
  • 测评结果:AC
  • 用时:634ms
  • 内存:72484kb
  • [2024-12-04 22:36:50]
  • 提交

answer

///////////        
//                   //      //
//              ////////////////////
//                   //      //
//                 
///////////

//          
//          
//           //     //    ////////     /\     /////////
//           //     //   //      //          //       //
//            ////////   //      //    //    //       //
//                  //   //      //    //    //       //
//////////   ////////    //      //    //     /////////////

#pragma GCC optimize(3,"Ofast","inline")
#include <iostream>
#include <iomanip>
#include <algorithm>
#include <map>
#include <set>
#include <queue>
#include <string>
#include <cstring>
#include <cmath>
#include <list>
#include <stack>
#include <array>
#include <unordered_map>
#include <unordered_set>
#include <bitset>
#include <random>
#include <numeric>
#include <functional>
#include <optional>
#include <chrono>
//#include <Windows.h>

using namespace std;

#define fa(i,op,n) for (int i = op; i <= n; i++)
#define fb(j,op,n) for (int j = op; j >= n; j--)
#define pb push_back
#define HashMap unordered_map
#define HashSet unordered_set
#define var auto
#define all(i) i.begin(), i.end()
#define all1(i) i.begin() + 1,i.end()
#define endl '\n'
#define px first
#define py second

struct custom_hash {
	static uint64_t splitmix64(uint64_t x) {
		x ^= x << 13;
		x ^= x >> 7;
		x ^= x << 17;
		return x;
	}
	size_t operator () (uint64_t x) const {
		static const uint64_t FIXED_RANDOM = chrono::steady_clock::now().time_since_epoch().count(); // 时间戳
		return splitmix64(x + FIXED_RANDOM);
	}
};

using VI = vector<int>;
using VL = vector<long long>;
using ll = long long;
using ull = unsigned long long;
using db = double;
using pii = pair<int, int>;
using pll = pair<ll, ll>;

template<class T1, class T2>
ostream& operator<<(ostream& out, const pair<T1, T2>& p) {
	out << '(' << p.first << ", " << p.second << ')';
	return out;
}

template<typename T>
ostream& operator<<(ostream& out, const vector<T>& ve) {
	for (T i : ve)
		out << i << ' ';
	return out;
}

template<class T1, class T2>
ostream& operator<<(ostream& out, const map<T1, T2>& mp) {
	for (auto i : mp)
		out << i << '\n';
	return out;
}

template<typename ...T>
bool _debug(T... a) {
	((cout << a << ' '), ...);
	cout << endl;
	return -1;
}

const int INF = 0x3f3f3f3f;
const ll LNF = 0x3f3f3f3f3f3f3f3f;
int dx[8] = { 1, -1, 0, 0, 1, -1, 1, -1 };
int dy[8] = { 0, 0, 1, -1, 1, -1, -1, 1 };

//#include "Lynia.h"
namespace MyTools
{
	template <typename T>
	class Math;

	template <const int T>
	class ModInt;

}

namespace MT = MyTools;
using Math = MT::Math<ll>;
#define geo MT::Geo

const int mod = 1e9 + 7;
using mint = MT::ModInt<mod>;

const int N = 1e6 + 10;

void solve(int CASE)
{
	int n, k; cin >> n >> k;
	var a = vector<int>(n + 1);
	fa(i, 1, n)cin >> a[i];
	var dp = vector<int>(n + 1);
	var g = HashMap<int, vector<int>, custom_hash>(); // a[i] 的下标表
	var st = stack<int>();
	fa(i, 1, n) {
		g[a[i]].pb(i);

		while (st.size() and a[st.top()] <= a[i])st.pop();

		int last = 0;
		if (st.size() and a[st.top()] > a[i]) {
			// 出现过比自己大的
			dp[i] = dp[st.top()];
			last = st.top();
		}

		int id = g[a[i]].size() - k;
		if (id >= 0 and g[a[i]][id] > last) {
			ll cnt = g[a[i]][id] - last;
			dp[i] += cnt;
		}

		st.push(i);
	}
	ll ans = 0;
	fa(i, 1, n) {
		//cout << dp[i] << ' ';
		ans += dp[i];
	}//cout << endl;

	cout << ans << endl;
	return;
}

int main()
{
	//SetConsoleOutputCP(CP_UTF8);
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	int _ = 1;
	cin >> _;
	fa(i, 1, _)solve(i);
	return 0;
}

这程序好像有点Bug,我给组数据试试?

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3840kb

input:

2
5 2
1 3 3 2 2
4 3
1 4 2 1

output:

7
0

result:

ok 2 lines

Test #2:

score: 0
Accepted
time: 59ms
memory: 16964kb

input:

1
1000000 1
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...

output:

500000500000

result:

ok single line: '500000500000'

Test #3:

score: 0
Accepted
time: 114ms
memory: 3648kb

input:

158921
1 1
1
2 1
1 1
2 2
1 1
2 1
1 2
2 2
1 2
2 1
2 1
2 2
2 1
2 1
2 2
2 2
2 2
3 1
1 1 1
3 2
1 1 1
3 3
1 1 1
3 1
1 1 2
3 2
1 1 2
3 3
1 1 2
3 1
1 1 3
3 2
1 1 3
3 3
1 1 3
3 1
1 2 1
3 2
1 2 1
3 3
1 2 1
3 1
1 2 2
3 2
1 2 2
3 3
1 2 2
3 1
1 2 3
3 2
1 2 3
3 3
1 2 3
3 1
1 3 1
3 2
1 3 1
3 3
1 3 1
3 1
1 3 2
3 2...

output:

1
3
1
3
0
3
0
3
1
6
3
1
6
1
0
6
1
0
6
0
0
6
2
0
6
0
0
6
0
0
6
0
0
6
2
0
6
1
0
6
1
0
6
0
0
6
2
0
6
3
1
6
1
0
6
0
0
6
0
0
6
2
0
6
1
0
6
0
0
6
1
0
6
0
0
6
1
0
6
1
0
6
2
0
6
2
0
6
3
1
10
6
3
1
10
3
1
0
10
3
1
0
10
3
1
0
10
1
0
0
10
4
0
0
10
1
0
0
10
1
0
0
10
1
0
0
10
1
0
0
10
4
0
0
10
1
0
0
10
1
0
0
10
...

result:

ok 158921 lines

Test #4:

score: 0
Accepted
time: 59ms
memory: 15268kb

input:

1
1000000 1000
1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 1000000 1 100...

output:

498003996002

result:

ok single line: '498003996002'

Test #5:

score: 0
Accepted
time: 494ms
memory: 41644kb

input:

24
217838 1
11125 61539 156386 82530 15545 110745 20051 71328 216682 107717 24565 71482 196259 23920 79507 74383 81434 99615 50571 31499 93241 126374 205674 57290 166999 83044 89340 72667 55001 143151 30341 98608 191197 96249 176106 113045 116438 34417 92531 200248 38119 106697 24629 117110 129552 1...

output:

23726806041
1590954891
782239681
139362697540
3608208775
205782590
1992948
1449
78
2701
6
1
720
4660
34
9
91
21
1
18
3
10
1
1

result:

ok 24 lines

Test #6:

score: 0
Accepted
time: 634ms
memory: 72484kb

input:

26
946385 1
670117 545657 843923 412448 720179 557739 318687 474032 740066 816184 884900 216879 154424 237010 571714 191989 697715 453717 521834 329605 911786 112304 586798 162144 800808 303697 80404 576671 153923 684638 852686 842726 624241 934235 466016 691917 89781 33743 257181 791555 572665 1112...

output:

447822757305
14857662
13995820
5722
8260080
51681
7918210
1898855
99360
12597690
16005
2
4
1
2
1
6
2
66
1
205
6
1
3
3
1

result:

ok 26 lines

Test #7:

score: 0
Accepted
time: 59ms
memory: 3788kb

input:

200
5000 2161
4684 3947 3947 4684 3947 3947 3947 3947 3947 3947 3947 4684 3947 3947 4684 4684 3947 4684 3947 4684 3947 3947 4684 4684 3947 4684 4684 3947 4684 3947 3947 3947 4684 3947 4684 3947 4684 4684 4684 4684 3947 3947 4684 4684 3947 4684 3947 3947 4684 3947 3947 3947 3947 4684 4684 4684 4684 4...

output:

242143
9180
5417490
3741
1311390
1464616
10
954876
85078
2353898
116886
1426174
1525131
339076
1697403
1619491
298378
1017451
2189688
7230333
816003
1408681
1104841
18721
196629
183930
1648020
142311
622170
3123750
1239445
2845305
666
378
2151775
771732
53628
764466
719400
3145930
1309170
2934084
40...

result:

ok 200 lines

Test #8:

score: 0
Accepted
time: 58ms
memory: 3984kb

input:

200
5000 913
2320 1037 3761 2655 2518 3761 3761 2518 2655 2320 2320 2655 3761 2655 2655 2655 3761 1037 2518 2320 2655 3761 3761 2320 2655 2655 2655 3761 3761 2655 1037 1037 3761 2655 3761 3761 2518 1037 2655 2655 2655 1037 2655 2655 3761 2655 2518 3761 2655 2655 3761 2320 3761 1037 2655 3761 2655 10...

output:

2007353
659526
4851
1074110
7793
50721
3872
1296855
291466
1021735
4347
2116653
291546
1355481
2069595
2852466
3356688
23436
1137786
2741311
5480335
15400
190036
1276003
1371996
311655
200661
37401
2687721
1151403
288420
821121
20706
3519330
423663
1979055
2176741
2818912
2494261
2031120
935028
3685...

result:

ok 200 lines

Test #9:

score: 0
Accepted
time: 58ms
memory: 3968kb

input:

200
5000 3687
3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3352 3...

output:

863955
49505
3321
2019045
846951
2716673
862641
41328
1610115
997883
886005
1809003
1433971
969528
1260078
1999000
892257
1697403
3166912
1902225
2528043
1192740
685384
1159003
597871
971514
704444
303031
1345620
2620905
2741311
1824718
2198341
1599428
2481169
2978020
713415
1396956
3104249
935664
3...

result:

ok 200 lines

Test #10:

score: 0
Accepted
time: 299ms
memory: 11036kb

input:

10
100000 2
94544 89355 27274 33773 47528 80222 15567 14092 68058 98267 50970 89136 90894 82414 59629 91287 42501 44705 74453 27333 28140 68922 9266 28406 37382 68627 93457 22625 54080 17300 70695 40013 71485 36337 10788 75135 49078 8717 59548 77850 79555 42166 59535 92722 36629 83004 16499 12040 97...

output:

2320563456
539751689
773203936
5000050000
1117001578
1806965186
1081323936
44792736
1367510297
5000050000

result:

ok 10 lines

Test #11:

score: 0
Accepted
time: 273ms
memory: 10980kb

input:

10
100000 4
81704 77987 72356 68922 238 53382 8371 95506 21026 9878 82931 19141 32961 2545 66610 70597 96816 43039 27198 53362 17443 81823 62196 93750 47184 24420 7643 58994 56301 52750 75685 36251 21471 53434 58907 76608 47452 54443 30887 13650 71405 95798 17102 22991 95147 92572 80502 79701 86329 ...

output:

544405707
63251000
5000050000
18989586
984278848
251340949
37564723
605563725
203863704
317061758

result:

ok 10 lines

Test #12:

score: 0
Accepted
time: 54ms
memory: 3840kb

input:

422
4288 1198
2132 3445 1624 2132 3445 2132 3445 1624 1624 2132 3445 3445 3445 2132 2132 2132 2132 2132 3445 2132 2132 1624 3445 2132 1624 1624 2132 2132 2132 3445 3445 3445 3445 3445 2132 2132 3445 1624 3445 3445 3445 3445 2132 2132 1624 3445 1624 2132 3445 2132 3445 1624 3445 2132 1624 3445 2132 3...

output:

485415
4005
330548
24531
3413
2016
921403
3
17205
49455
38226
1524
1
225456
194880
179182
2060517
277140
358281
709836
69751
592329
83436
229838
18721
1056331
10296
753378
8385
179104
6
1615070
1521640
155403
2543640
95703
15296
2563655
1770
17020
372031
1298466
159099
19503
57970
79704
177906
1
139...

result:

ok 422 lines

Test #13:

score: 0
Accepted
time: 59ms
memory: 3836kb

input:

412
2693 2138
994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 994 99...

output:

154846
834796
1966002
196878
406
2299440
1306877
1247410
814726
4753
465
21115
163062
30135
57630
24
2063496
147153
79
317774
8385
295296
89676
114003
1570878
298378
30381
110557
100866
2089375
780
398278
936396
73536
45753
378
34260
235641
2130383
70125
1760626
2628
3486
40
9730
19110
1008825
6328
...

result:

ok 412 lines

Test #14:

score: 0
Accepted
time: 63ms
memory: 18404kb

input:

1
999999 10
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...

output:

176106219446

result:

ok single line: '176106219446'

Test #15:

score: 0
Accepted
time: 51ms
memory: 15524kb

input:

1
1000000 1000000
714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 714444 71...

output:

1

result:

ok single line: '1'

Test #16:

score: 0
Accepted
time: 425ms
memory: 65444kb

input:

1
1000000 2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 ...

output:

250000000000

result:

ok single line: '250000000000'

Test #17:

score: 0
Accepted
time: 432ms
memory: 65644kb

input:

1
1000000 2
1000000 999999 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999985 999984 999983 999982 999981 999980 999979 999978 999977 999976 999975 999974 999973 999972 999971 999970 999969 999968 999967 999966 999965 999964 999963 999962 999961 999960 ...

output:

500000

result:

ok single line: '500000'

Test #18:

score: 0
Accepted
time: 53ms
memory: 15048kb

input:

1
1000000 3
1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 16 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 32 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 16 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 64 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 16 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 32 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 16 1 2 1 4 1 2 1 8 1 2 1 4 1 2 1 128 1 2 1 4 1 2 1 8 1 2 1 4...

output:

0

result:

ok single line: '0'

Extra Test:

score: 0
Extra Test Passed