日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

IQ测试(jzoj 5048)

發(fā)布時(shí)間:2023/12/3 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 IQ测试(jzoj 5048) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

IQ測(cè)試

jzoj 5048

題目大意

給出一個(gè)序列a,然后有m個(gè)詢(xún)問(wèn),每個(gè)詢(xún)問(wèn)給出一個(gè)序列,問(wèn)這個(gè)序列是否可以由序列a刪掉一些數(shù)得到的

輸入樣例

7 1 5 4 5 7 8 6 4 5 1 5 5 8 6 3 2 2 2 3 5 7 8 4 1 5 7 4

輸出樣例

TAK NIE TAK NIE

數(shù)據(jù)范圍

對(duì)于30%的數(shù)據(jù):n?1000,m?1000n\leqslant 1000,m\leqslant 1000n?1000,m?1000
對(duì)于100%的數(shù)據(jù):1?ai,bi?1000000,∑L?1000000,n,m?10000001\leqslant ai,bi\leqslant 1000000,\sum L\leqslant 1000000,n,m\leqslant 10000001?ai,bi?1000000L?1000000n,m?1000000

解題思路

數(shù)據(jù)有1000000這么大,那應(yīng)該就是o(n)o(n)on左右的
數(shù)據(jù)寫(xiě)到∑L?1000000\sum L\leqslant 1000000L?1000000,那他就一定有他的作用
我們把所有序列放在一起看
我們可以枚舉序列a,對(duì)于每一個(gè)數(shù)
如果和某個(gè)序列的指針?biāo)赶虻臄?shù)字相同,那我們就把這個(gè)序列的指針指向下一位,就是當(dāng)前數(shù)字已找到
如果一個(gè)序列可以按順序在序列a中找到它的每一個(gè)數(shù),那它就是符合的
但如果每一個(gè)序列都搜一遍的話(huà)就會(huì)TLETLETLE
我們可以用一個(gè)數(shù)組來(lái)記錄指針指向某個(gè)數(shù)字的序列有哪些

代碼

#include<vector> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define ll long long using namespace std; int n, m, w, g, a[1000010], s[1000010]; vector<int>h[1000010], b[1000010];//要用vector才能即不超時(shí)又不超內(nèi)存 int main() {scanf("%d", &n);for (int i = 1; i <= n; ++i)scanf("%d", &a[i]);scanf("%d", &m);for (int i = 1; i <= m; ++i){scanf("%d", &w);for (int j = 1; j <= w; ++j){scanf("%d", &g);b[i].push_back(g);}h[b[i].front()].push_back(i);//第一個(gè)數(shù)}for (int i = 1; i <= n; ++i){w = h[a[i]].size();//指針指向a[i]序列數(shù)for (int j = 0; j < w; ++j){g = h[a[i]][j];//第幾個(gè)序列s[g]++;//指針加一if (s[g] < b[g].size()) h[b[g][s[g]]].push_back(g);//沒(méi)有遍歷完,再指向下一個(gè)}h[a[i]].erase(h[a[i]].begin(), h[a[i]].begin() + w);//刪掉原有的}for (int i = 1; i <= m; ++i)if (s[i] >= b[i].size()) printf("TAK\n");//遍歷完的else printf("NIE\n");return 0; }

總結(jié)

以上是生活随笔為你收集整理的IQ测试(jzoj 5048)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。