QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#885926#4890. 这是一道集训队胡策题LinkWish100 ✓1175ms102268kbC++142.9kb2025-02-06 19:37:402025-02-06 19:37:46

Judging History

This is the latest submission verdict.

  • [2025-02-06 19:37:46]
  • Judged
  • Verdict: 100
  • Time: 1175ms
  • Memory: 102268kb
  • [2025-02-06 19:37:40]
  • Submitted

answer

//Linkwish's code
#include<bits/stdc++.h>
#define endl '\n'
#define si inline
#define fi first
#define se second
using namespace std;
typedef long long ll;typedef __int128 li;typedef long double ld;typedef unsigned long long ull;
typedef pair<int,int> pii;typedef pair<ll,ll> pll;
typedef const int ci;typedef const ll cl;ci iinf=INT_MAX;cl linf=LLONG_MAX;
template<typename T>si bool gmax(T &x,const T y){if(x<y)return x=y,1;return 0;}
template<typename T>si bool gmin(T &x,const T y){if(y<x)return x=y,1;return 0;}

namespace LinkWish{
	
	ci N=5005,mod=998244353;

	int n,a[N][N];
	int cnt[N];

	ci M=80;
	struct Bit{
		ull v[M];
		si Bit(){memset(v,0,sizeof v);}
		si Bit Flip()const{
			Bit tmp;
			for(int i=0;i<M;i++)tmp.v[i]=~v[i];
			return tmp;
		}
		si void Set(int pos){
			v[pos>>6]|=(1ll<<(pos&63));
		}
		si int Val(int pos)const{
			return (v[pos>>6]>>(pos&63))&1;
		}
		si Bit operator & (const Bit &obj)const{
			Bit res;
			for(int i=0;i<M;i++)res.v[i]=v[i]&obj.v[i];
			return res;
		}
		si Bit operator | (const Bit &obj)const{
			Bit res;
			for(int i=0;i<M;i++)res.v[i]=v[i]|obj.v[i];
			return res;
		}
		si Bit operator ^ (const Bit &obj)const{
			Bit res;
			for(int i=0;i<M;i++)res.v[i]=v[i]^obj.v[i];
			return res;
		}
		si bool operator < (const Bit &obj)const{
			for(int i=0;i<M;i++){
				if(v[i]<obj.v[i])return true;
				if(v[i]>obj.v[i])return false;
			}
			return false;
		}
		si bool operator == (const Bit &obj)const{
			for(int i=0;i<M;i++)if(v[i]!=obj.v[i])return false;
			return true;
		}
	};
	
	struct T{
		Bit lock,val;
		si bool operator < (const T &obj)const{
			if(lock==obj.lock)return val<obj.val;
			return lock<obj.lock;
		}
	};

	map<T,int> f[2];

	void mian(){
		cin>>n;
		for(int i=1;i<=n;i++){
			string s;cin>>s;
			for(int j=1;j<=n;j++)a[i][j]=s[j-1]-'0',cnt[i]+=a[i][j];
		}
		
		vector<int> pos(n);
		iota(pos.begin(),pos.end(),1);
		sort(pos.begin(),pos.end(),[&](int x,int y){return cnt[x]>cnt[y];});

		T tmp;
		f[0][tmp]=1;
		int now=0,nxt=1;
		for(int i:pos){
			f[nxt].clear();
			for(int c=0;c<2;c++){
				Bit pos;
				for(int j=1;j<=n;j++)if(a[i][j]!=c)pos.Set(j);
				for(auto &v:f[now]){
					if(c==0){
						Bit nlk=(v.fi.lock.Flip()|v.fi.val);
						if((nlk&pos)==pos){
							tmp.lock=v.fi.lock|pos;
							tmp.val=v.fi.val|pos;
							(f[nxt][tmp]+=v.se)%=mod;
						}
					}
					else{
						Bit nlk=(v.fi.lock.Flip()|(v.fi.lock^v.fi.val));
						if((nlk&pos)==pos){
							tmp.lock=v.fi.lock|pos;
							tmp.val=v.fi.val;
							(f[nxt][tmp]+=v.se)%=mod;
						}
					}
				}
			}
			swap(now,nxt);
		}

		int ans=0;
		for(auto &v:f[now]){
			int res=v.se;
			for(int j=1;j<=n;j++)if(!v.fi.lock.Val(j))res=(res+res)%mod;
			(ans+=res)%=mod;
		}

		cout<<ans<<endl;
	}
}

signed main(){
	ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	LinkWish::mian();
	return 0;
}

这程序好像有点Bug,我给组数据试试?

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 5
Accepted

Test #1:

score: 5
Accepted
time: 0ms
memory: 5900kb

input:

10
0000000000
0101111001
0101111001
0101111001
0101111001
0101111001
0101111001
0101111001
0101111001
0101111001

output:

591

result:

ok 1 number(s): "591"

Test #2:

score: 5
Accepted
time: 0ms
memory: 3840kb

input:

10
0000000000
0001100000
0001111111
0001111111
0001100000
0001111111
0001110100
0001110100
0001110100
0001110100

output:

47

result:

ok 1 number(s): "47"

Test #3:

score: 5
Accepted
time: 0ms
memory: 5744kb

input:

10
1000000000
1010000000
1010000000
1010111111
1010100111
1010100111
1010100111
1010100100
1010100100
1010100110

output:

30

result:

ok 1 number(s): "30"

Test #4:

score: 5
Accepted
time: 1ms
memory: 3840kb

input:

10
0000110001
0101100000
0100001111
1011000001
0011010000
1010011111
1000111100
1110111101
1000101100
1000110100

output:

2

result:

ok 1 number(s): "2"

Test #5:

score: 5
Accepted
time: 0ms
memory: 3712kb

input:

10
1000010100
1100001111
1111010111
1010000001
1000110111
0100001001
1000111110
0110100010
1010100010
1010110111

output:

2

result:

ok 1 number(s): "2"

Test #6:

score: 5
Accepted
time: 0ms
memory: 5864kb

input:

10
1011001000
1011111011
0111010011
0011110000
0000011100
0101000000
1001100000
1111010011
1110111101
1100010101

output:

2

result:

ok 1 number(s): "2"

Subtask #2:

score: 15
Accepted

Test #7:

score: 15
Accepted
time: 1ms
memory: 5892kb

input:

20
11110010101111111000
01000101111110100000
10110001010110111101
10111111011011110101
10110101011010111101
00010100011011001011
01111111001000101001
10101101011101011100
11011010110101011110
00010100101000001011
00001010100111101100
00100111010010101001
00000010010110110110
11011111100110111100
010...

output:

2

result:

ok 1 number(s): "2"

Test #8:

score: 15
Accepted
time: 0ms
memory: 5928kb

input:

20
01000110110000100100
00010110001100011000
11111000101101101010
10010001100000010100
01101101000000111100
10010111110101011101
00000101010000000110
00001100101111111110
11111110111001101001
00010000001000101011
00010010110110110011
01011011110010011110
01000101111111011101
00010111001101001110
101...

output:

2

result:

ok 1 number(s): "2"

Test #9:

score: 15
Accepted
time: 1ms
memory: 3840kb

input:

20
00000000000000000000
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
10011101011010000010
100...

output:

526847

result:

ok 1 number(s): "526847"

Test #10:

score: 15
Accepted
time: 0ms
memory: 3840kb

input:

20
00000000000000000000
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
11101100001001010011
111...

output:

526335

result:

ok 1 number(s): "526335"

Test #11:

score: 15
Accepted
time: 0ms
memory: 3712kb

input:

20
10000000000000000000
11111000110000000000
11111000110000000000
11111000111111111111
11111000111111111111
11111000111111111111
11111000110000000000
11111000111111111111
11111000110000000000
11111000111111111111
11111000111111111111
11111000111010011011
11111000111010011011
11111000111010011011
111...

output:

740

result:

ok 1 number(s): "740"

Test #12:

score: 15
Accepted
time: 0ms
memory: 3712kb

input:

20
10000000000000000000
11110100100000000000
11110100101111111111
11110100100000000000
11110100100000000000
11110100100000000000
11110100101111111111
11110100100000000000
11110100101111111111
11110100101111111111
11110100100000000000
11110100100010000000
11110100100010000000
11110100100010000000
111...

output:

1150

result:

ok 1 number(s): "1150"

Test #13:

score: 15
Accepted
time: 0ms
memory: 3840kb

input:

20
11111111111111111111
10100111111111111111
10100100000000000000
10100100000000000000
10100111111111111111
10100100000000000000
10100100000000000000
10100111001100101111
10100111001100101111
10100111001100100000
10100111001100101111
10100111001100100000
10100111001100100000
10100111001100101111
101...

output:

189

result:

ok 1 number(s): "189"

Subtask #3:

score: 40
Accepted

Test #14:

score: 40
Accepted
time: 1ms
memory: 10296kb

input:

300
01110011110110110011100111010000101110110001000111111011100101101101101011110101110100110110001110111010101011111010010101001000100011001110110100110000111001011011100000011100000000000001101000010110110000110001110000010110100010110110111000110000100101110011111010001100110111001010000100110110...

output:

2

result:

ok 1 number(s): "2"

Test #15:

score: 40
Accepted
time: 1ms
memory: 10092kb

input:

300
00101101101001110001110111101010000101010101100001110010001101001011011110111000110110101101111100010010011111010011101011110001011011111110001110100110101010100111001110001100111011010110010010111101001001101000000000011101011000111100101000101110111011001111111000111000100111100110101001011101...

output:

2

result:

ok 1 number(s): "2"

Test #16:

score: 40
Accepted
time: 1ms
memory: 9892kb

input:

300
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...

output:

936335109

result:

ok 1 number(s): "936335109"

Test #17:

score: 40
Accepted
time: 1ms
memory: 10268kb

input:

300
10000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...

output:

124904823

result:

ok 1 number(s): "124904823"

Test #18:

score: 40
Accepted
time: 1ms
memory: 10100kb

input:

300
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

923149686

result:

ok 1 number(s): "923149686"

Test #19:

score: 40
Accepted
time: 3ms
memory: 10100kb

input:

300
01111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

254929271

result:

ok 1 number(s): "254929271"

Test #20:

score: 40
Accepted
time: 10ms
memory: 10008kb

input:

300
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

12177

result:

ok 1 number(s): "12177"

Subtask #4:

score: 5
Accepted

Test #21:

score: 5
Accepted
time: 243ms
memory: 101500kb

input:

5000
0000111111000001000100111100110001110111011000101000110111100011111110110011101001111001111101010001111101110011110101010011010010000000001111000111101111010010110100000110111101100000010111111110001001010100101110100010100000011100000101011011101010011111101011000110001001011010000010000101111...

output:

2

result:

ok 1 number(s): "2"

Test #22:

score: 5
Accepted
time: 250ms
memory: 101556kb

input:

5000
0010011001001111110110000001101010000101010111000001101101011100001001011101010000001111010001101001111000101001011011001000111110010001111011011101010000110000010100010110011010000110111110111100110100001010110010001011010010001001101110000000111110111111000110000011010011100001110011111010001...

output:

2

result:

ok 1 number(s): "2"

Test #23:

score: 5
Accepted
time: 248ms
memory: 101560kb

input:

5000
1100111111010100100110101001011111001111000111111010110110010101011010010001111010101001101110111111100100101111010111001111100001100101111111000010100011000110100010010110111111100001100010000111101011110111100010010000001110011110001110110001000101111010110011111001111001011011110010101000000...

output:

2

result:

ok 1 number(s): "2"

Subtask #5:

score: 35
Accepted

Test #24:

score: 35
Accepted
time: 95ms
memory: 101428kb

input:

5000
0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...

output:

828414647

result:

ok 1 number(s): "828414647"

Test #25:

score: 35
Accepted
time: 92ms
memory: 101596kb

input:

5000
0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...

output:

16621460

result:

ok 1 number(s): "16621460"

Test #26:

score: 35
Accepted
time: 254ms
memory: 101412kb

input:

5000
1010110111100100001010010010100011000101011011111111101001100001101101011001001110101011110101001110010011110111101001011010010001100100111010100100000011101101000100010001011001101100000000000000011001100101111101110010111101000000010001000101110111100011100110101001001000001101111010001111010...

output:

2

result:

ok 1 number(s): "2"

Test #27:

score: 35
Accepted
time: 587ms
memory: 101788kb

input:

5000
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

541497915

result:

ok 1 number(s): "541497915"

Test #28:

score: 35
Accepted
time: 177ms
memory: 101620kb

input:

5000
0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000...

output:

288388087

result:

ok 1 number(s): "288388087"

Test #29:

score: 35
Accepted
time: 211ms
memory: 101740kb

input:

5000
0111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

352199570

result:

ok 1 number(s): "352199570"

Test #30:

score: 35
Accepted
time: 1175ms
memory: 102268kb

input:

5000
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111...

output:

410201481

result:

ok 1 number(s): "410201481"

Extra Test:

score: 0
Extra Test Passed