社区讨论

警钟长鸣,如果你想用数组

B3618寻找团伙参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@m07sojf5
此快照首次捕获于
2024/08/24 15:04
2 年前
此快照最后确认于
2025/11/04 22:33
4 个月前
查看原帖
千万别用,别问我咋知道的
用了就是TLE
如下图:
奉上TLE代码:
CPP
#include<bits/stdc++.h>
using namespace std;
int n , k;
bool vis[30];
int a[30] , a1[100][100];
unsigned long long maxx = 0;
void dfs(int n1){
	int cnt[100] = {};
	unsigned long long sum = 0;
    for(int i = 1; i < n1; i++){
    	for(int j = 1; j <= k; j++){
    		cnt[j] += a1[a[i]][j];
		}
	}
	for(int j = 1; j <= k; j++){
		if(cnt[j] % 2 == 1){
			sum += pow(2 , k - j);
		}
	}
	maxx = max(maxx , sum);
	if(n1 == n + 1){
        return;
    }
    for(int i = a[n1 - 1] + 1; i <= n; i++){
        a[n1] = i;
        dfs(n1 + 1);
    }
}
int main(){
    cin >> n >> k;
    for(int i = 1; i <= n; i++){
    	int t;
    	cin >> t;
    	for(int j = 1; j <= t; j++){
    		int t1;
    		cin >> t1;
    		a1[i][t1]++;
		}
	}
	dfs(1);
	cout << maxx;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...