离散题目7
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
DaYu在新的学习开始学习新的数学知识,一天DaYu学习集合的时候遇到一个问题,他有一个集合A和A的子集B,他想用一个二进制串表示集合B。
Input
多组输入,每组的第一行有两个数n,m,(0< m < n < 10^5).
第二行输入n个数表示集合A,第三行输入m个数表示集合B,|data_i|< 10^5
Output
输出一个01字符串表示集合B
Example Input
10 5 1 2 3 4 5 6 7 8 9 10 1 3 5 7 8
Example Output
1010101100
本题就是对比两个集合,如果同时存在就是1, 反之就是0;但如果用两层for会超时,所以用一下桶的思想将时间复杂度降到O(n);
代码:
#include <bits/stdc++.h>
using namespace std;
int main() { int n, m, i, v, x[100004], vid[200004]; while(scanf("%d %d", &n, &m) != EOF) { for(i = 0; i < n; i++) { scanf("%d", &x[i]); vid[x[i]+100000] = 0; } for(i = 0; i < m; i++) { scanf("%d", &v); vid[v+100000] = 1; } for(i = 0; i < n; i++) { printf("%d", vid[x[i]+100000]); } printf("\n"); } return 0; }