提出 #73651307
ソースコード 拡げる
#include <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
#include <numeric>
using namespace std;
// 定义查询结构体,保存左右端点、查询索引
struct Query {
int l, r, idx;
};
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int N, Q;
cin >> N >> Q;
vector<int> P(N + 1); // 花卉品种,下标从1开始(匹配题目中的花床编号)
for (int i = 1; i <= N; ++i) {
cin >> P[i];
}
// 读取所有查询
vector<Query> queries(Q);
for (int i = 0; i < Q; ++i) {
cin >> queries[i].l >> queries[i].r;
queries[i].idx = i;
}
// 分块大小:取√N(经验值,优化常数)
int block_size = sqrt(N) + 1;
// 排序规则:按左端点所在块排序,同块内右端点奇偶性优化(减少指针移动)
sort(queries.begin(), queries.end(), [&](const Query& a, const Query& b) {
if (a.l / block_size != b.l / block_size) {
return a.l / block_size < b.l / block_size;
}
// 奇数块右端点升序,偶数块降序(奇偶排序优化)
return (a.l / block_size % 2) ? (a.r > b.r) : (a.r < b.r);
});
// 初始化双指针和统计变量
int cur_l = 1, cur_r = 0;
int distinct_count = 0;
vector<int> freq(N + 2, 0); // 记录每个品种的出现次数(P_i≤N)
vector<int> ans(Q); // 保存每个查询的答案
// 处理每个查询
for (const auto& q : queries) {
int l = q.l, r = q.r, idx = q.idx;
// 扩展右指针到r
while (cur_r < r) {
cur_r++;
if (freq[P[cur_r]] == 0) {
distinct_count++;
}
freq[P[cur_r]]++;
}
// 收缩右指针到r
while (cur_r > r) {
freq[P[cur_r]]--;
if (freq[P[cur_r]] == 0) {
distinct_count--;
}
cur_r--;
}
// 扩展左指针到l
while (cur_l > l) {
cur_l--;
if (freq[P[cur_l]] == 0) {
distinct_count++;
}
freq[P[cur_l]]++;
}
// 收缩左指针到l
while (cur_l < l) {
freq[P[cur_l]]--;
if (freq[P[cur_l]] == 0) {
distinct_count--;
}
cur_l++;
}
// 记录当前查询的答案
ans[idx] = distinct_count;
}
// 按原始顺序输出答案
for (int x : ans) {
cout << x << '\n';
}
return 0;
}
提出情報
| 提出日時 | |
|---|---|
| 問題 | E - 花の種類を数えよう |
| ユーザ | a_computers_xh |
| 言語 | C++23 (GCC 15.2.0) |
| 得点 | 466 |
| コード長 | 2757 Byte |
| 結果 | AC |
| 実行時間 | 65 ms |
| メモリ | 5812 KiB |
ジャッジ結果
| セット名 | Sample | All | ||||
|---|---|---|---|---|---|---|
| 得点 / 配点 | 0 / 0 | 466 / 466 | ||||
| 結果 |
|
|
| セット名 | テストケース |
|---|---|
| Sample | sample01.txt, sample02.txt, sample03.txt |
| All | sample01.txt, sample02.txt, sample03.txt, in01.txt, in02.txt, in03.txt, in04.txt, in05.txt, in06.txt, in07.txt, in08.txt, in09.txt, in10.txt, in11.txt, in12.txt, in13.txt, in14.txt, in15.txt, in16.txt, in17.txt, in18.txt, in19.txt, in20.txt, in21.txt, in22.txt, in23.txt, in24.txt, in25.txt, in26.txt, in27.txt, in28.txt, in29.txt, in30.txt, in31.txt, in32.txt, in33.txt, in34.txt, in35.txt, in36.txt, in37.txt, in38.txt, in39.txt, in40.txt, in41.txt, in42.txt, in43.txt, in44.txt, in45.txt, in46.txt, in47.txt, in48.txt, in49.txt, in50.txt, in51.txt, in52.txt, in53.txt, in54.txt, in55.txt, in56.txt, in57.txt, in58.txt, in59.txt, in60.txt, in61.txt, in62.txt, in63.txt, in64.txt, in65.txt, in66.txt, in67.txt, in68.txt, in69.txt, in70.txt, in71.txt, in72.txt, in73.txt, in74.txt |
| ケース名 | 結果 | 実行時間 | メモリ |
|---|---|---|---|
| in01.txt | AC | 1 ms | 3576 KiB |
| in02.txt | AC | 1 ms | 3668 KiB |
| in03.txt | AC | 1 ms | 3452 KiB |
| in04.txt | AC | 1 ms | 3556 KiB |
| in05.txt | AC | 1 ms | 3576 KiB |
| in06.txt | AC | 1 ms | 3476 KiB |
| in07.txt | AC | 1 ms | 3536 KiB |
| in08.txt | AC | 1 ms | 3492 KiB |
| in09.txt | AC | 46 ms | 5800 KiB |
| in10.txt | AC | 39 ms | 5804 KiB |
| in11.txt | AC | 46 ms | 5696 KiB |
| in12.txt | AC | 40 ms | 5776 KiB |
| in13.txt | AC | 4 ms | 4136 KiB |
| in14.txt | AC | 4 ms | 4164 KiB |
| in15.txt | AC | 4 ms | 4168 KiB |
| in16.txt | AC | 38 ms | 5656 KiB |
| in17.txt | AC | 16 ms | 5672 KiB |
| in18.txt | AC | 24 ms | 5704 KiB |
| in19.txt | AC | 38 ms | 5656 KiB |
| in20.txt | AC | 65 ms | 5800 KiB |
| in21.txt | AC | 40 ms | 5812 KiB |
| in22.txt | AC | 40 ms | 5728 KiB |
| in23.txt | AC | 49 ms | 5656 KiB |
| in24.txt | AC | 31 ms | 5660 KiB |
| in25.txt | AC | 16 ms | 5656 KiB |
| in26.txt | AC | 39 ms | 5776 KiB |
| in27.txt | AC | 12 ms | 4936 KiB |
| in28.txt | AC | 1 ms | 3704 KiB |
| in29.txt | AC | 1 ms | 3668 KiB |
| in30.txt | AC | 1 ms | 3700 KiB |
| in31.txt | AC | 1 ms | 3580 KiB |
| in32.txt | AC | 24 ms | 5704 KiB |
| in33.txt | AC | 18 ms | 5244 KiB |
| in34.txt | AC | 1 ms | 3404 KiB |
| in35.txt | AC | 1 ms | 3556 KiB |
| in36.txt | AC | 1 ms | 3668 KiB |
| in37.txt | AC | 1 ms | 3476 KiB |
| in38.txt | AC | 1 ms | 3484 KiB |
| in39.txt | AC | 1 ms | 3556 KiB |
| in40.txt | AC | 1 ms | 3556 KiB |
| in41.txt | AC | 1 ms | 3720 KiB |
| in42.txt | AC | 2 ms | 3720 KiB |
| in43.txt | AC | 27 ms | 5800 KiB |
| in44.txt | AC | 27 ms | 5728 KiB |
| in45.txt | AC | 21 ms | 5780 KiB |
| in46.txt | AC | 16 ms | 5696 KiB |
| in47.txt | AC | 18 ms | 5660 KiB |
| in48.txt | AC | 35 ms | 5672 KiB |
| in49.txt | AC | 31 ms | 5144 KiB |
| in50.txt | AC | 31 ms | 5696 KiB |
| in51.txt | AC | 30 ms | 5676 KiB |
| in52.txt | AC | 44 ms | 5800 KiB |
| in53.txt | AC | 31 ms | 5344 KiB |
| in54.txt | AC | 43 ms | 5812 KiB |
| in55.txt | AC | 33 ms | 5672 KiB |
| in56.txt | AC | 39 ms | 5656 KiB |
| in57.txt | AC | 44 ms | 5704 KiB |
| in58.txt | AC | 45 ms | 5728 KiB |
| in59.txt | AC | 1 ms | 3576 KiB |
| in60.txt | AC | 1 ms | 3532 KiB |
| in61.txt | AC | 38 ms | 5772 KiB |
| in62.txt | AC | 38 ms | 5704 KiB |
| in63.txt | AC | 1 ms | 3484 KiB |
| in64.txt | AC | 1 ms | 3584 KiB |
| in65.txt | AC | 1 ms | 3512 KiB |
| in66.txt | AC | 1 ms | 3576 KiB |
| in67.txt | AC | 1 ms | 3576 KiB |
| in68.txt | AC | 1 ms | 3444 KiB |
| in69.txt | AC | 1 ms | 3488 KiB |
| in70.txt | AC | 1 ms | 3484 KiB |
| in71.txt | AC | 4 ms | 4168 KiB |
| in72.txt | AC | 4 ms | 4264 KiB |
| in73.txt | AC | 44 ms | 5812 KiB |
| in74.txt | AC | 40 ms | 5672 KiB |
| sample01.txt | AC | 1 ms | 3452 KiB |
| sample02.txt | AC | 1 ms | 3428 KiB |
| sample03.txt | AC | 1 ms | 3532 KiB |