제출 #1160854

#제출 시각아이디문제언어결과실행 시간메모리
1160854Celebi_276Selling RNA Strands (JOI16_selling_rna)C++20
100 / 100
185 ms251908 KiB
#include <bits/stdc++.h> using namespace std; #define FILE "TEST" #define TIME (1.0 * clock() / CLOCKS_PER_SEC) #define ll long long #define all(v) v.begin(), v.end() template<class X, class Y> bool minimize(X &x, Y y) { if (x > y) { x = y; return true; } return false; } template<class X, class Y> bool maximize(X &x, Y y) { if (x < y) { x = y; return true; } return false; } const int N = 2E6 + 26; struct Node { int child[4]; int minId, maxId; Node() { minId = 2E9 + 29; maxId = 0; for (int i = 0; i < 4; i++) child[i] = 0; } } FTrie[N]; struct RNode { int child[4]; vector <int> idList; RNode() { for (int i = 0; i < 4; i++) child[i] = 0; } } RTrie[N]; short key[91]; int cntNode[2], n, m; string RNA[N]; void addString (string &s, int id) { int u = 0; for (int i = 0; i < s.length(); i++) { int k = key[s[i]]; if (!FTrie[u].child[k]) FTrie[u].child[k] = ++cntNode[0]; u = FTrie[u].child[k]; minimize(FTrie[u].minId, id); maximize(FTrie[u].maxId, id); } } pair <int, int> getRange (string &pr) { int u = 0; for (int i = 0; i < pr.length(); i++) { int k = key[pr[i]]; if (!FTrie[u].child[k]) return {-1, -1}; u = FTrie[u].child[k]; } return {FTrie[u].minId, FTrie[u].maxId}; } void addRevString (string &s, int id) { int u = 0; for (int i = s.length() - 1; i >= 0; i--) { int k = key[s[i]]; if (!RTrie[u].child[k]) RTrie[u].child[k] = ++cntNode[1]; u = RTrie[u].child[k]; RTrie[u].idList.push_back(id); } } int getQuery (string &s, int l, int r) { int u = 0; for (int i = s.length() - 1; i >= 0; i--) { int k = key[s[i]]; if (!RTrie[u].child[k]) return 0; u = RTrie[u].child[k]; } return upper_bound(all(RTrie[u].idList), r) - lower_bound(all(RTrie[u].idList), l); } signed main () { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); if (fopen(FILE".INP", "r")) { freopen(FILE".INP", "r", stdin); freopen(FILE".OUT", "w", stdout); } key['A'] = 0; key['C'] = 1; key['G'] = 2; key['U'] = 3; cin >> n >> m; for (int i = 1; i <= n; i++) cin >> RNA[i]; sort(RNA + 1, RNA + 1 + n); for (int i = 1; i <= n; i++) { addString(RNA[i], i); addRevString(RNA[i], i); } for (int j = 1; j <= m; j++) { string P, Q; cin >> P >> Q; int l, r; tie(l, r) = getRange(P); cout << getQuery(Q, l, r) << "\n"; } return 0; }

컴파일 시 표준 에러 (stderr) 메시지

selling_rna.cpp: In function 'int main()':
selling_rna.cpp:90:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   90 |         freopen(FILE".INP", "r", stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
selling_rna.cpp:91:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   91 |         freopen(FILE".OUT", "w", stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...