UOJ Logo

NOI.AC

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#211378#3806. 逃跑drdilyor902967ms18768kbC++111.5kb2024-08-11 08:44:222024-08-11 13:01:04

answer

#include<bits/stdc++.h>
#define int long long
using namespace std;
void ts(){cout<<"IAKIOI\n";}
inline int read(){
	int n=0,f=1,ch=getchar();
	while(ch<'0'||ch>'9'){
		if(ch=='-')f=-1;
		ch=getchar();
	}
	while(ch>='0'&&ch<='9'){
		n=n*10+ch-'0';
		ch=getchar();
	}
	return n*f;
}
const int mod=998244353;
struct mint{
    int x;mint(int o=0){x=o;}mint&operator+=(mint a){return(x+=a.x)%=mod,*this;}mint&operator-=(mint a){return(x+=mod-a.x)%=mod,*this;}
    mint&operator*=(mint a){return(x=1ll*x*a.x%mod),*this;}mint&operator^=( int b){mint a=*this;x=1;while(b)(b&1)&&(*this*=a,1),a*=a,b>>=1;return*this;}
    mint&operator/=(mint a){return*this*=(a^=mod-2);}friend mint operator+(mint a,mint b){return a+=b;}friend mint operator-(mint a,mint b){return a-=b;}
    friend mint operator*(mint a,mint b){return a*=b;}friend mint operator/(mint a,mint b){return a/=b;}friend mint operator^(mint a,int b){return a^=b;}
    mint operator-(){return 0-*this;}bool operator==(const mint b)const{return x==b.x;}
};
int n,m,k;
int a[200005][9];
signed main(){
	n=read(),m=read(),k=read();
	for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)a[i][j]=read();
	int res=0;
	for(int i=0;i<(1<<m);i++){
		vector<int> p;
		int cnt=0;
		for(int j=1;j<=n;j++){
			int tt=0;
			for(int k=1;k<=m;k++){
				if(i&(1<<(k-1)))tt+=a[j][k];
				else tt-=a[j][k];
			}
			p.push_back(tt);
		}
		sort(p.begin(),p.end());
		reverse(p.begin(),p.end());
		for(int j=0;j<k;j++)cnt+=p[j];
		res=max(res,cnt);
	}
	printf("%lld\n",res);
	return 0;
}

详细

小提示:点击横条可展开更详细的信息

Test #1:

score: 10
Accepted
time: 0ms
memory: 1208kb

input:

16 6 10
-8117570516 9044069943 -8048766531 -8085807376 9028744360 -2291836940
8616476021 250513762 9...

output:

231924481827

result:

ok "231924481827"

Test #2:

score: 10
Accepted
time: 1ms
memory: 1212kb

input:

18 8 15
-6677000484 -1719283852 4578001104 8068813014 -80018326 4784041624 -1445243501 5746477070
-4...

output:

266922244841

result:

ok "266922244841"

Test #3:

score: 10
Accepted
time: 30ms
memory: 9888kb

input:

100000 1 30000
-8076175068
4904794051
9104341999
1200537137
7000920774
9670819374
-8604644357
-63778...

output:

210324135222440

result:

ok "210324135222440"

Test #4:

score: 10
Accepted
time: 58ms
memory: 18768kb

input:

200000 1 150000
-2272499492
-8807500507
3725379627
7512017895
4166123214
1269935574
-8584261761
-751...

output:

378098351320197

result:

ok "378098351320197"

Test #5:

score: 10
Accepted
time: 63ms
memory: 9892kb

input:

100000 2 50000
5241196316 8333678776
-5242651186 5299526105
9464328294 -6643098907
-7209213944 -2118...

output:

334633112402130

result:

ok "334633112402130"

Test #6:

score: 10
Accepted
time: 94ms
memory: 9888kb

input:

100000 3 77777
-6171366053 3327407178 6863027058
-2358761813 -865379553 7668502806
-1462046286 16445...

output:

301554475123255

result:

ok "301554475123255"

Test #7:

score: 10
Accepted
time: 147ms
memory: 9888kb

input:

100000 4 80000
1342329756 468586460 -1031261932 -4571220835
8804945368 3053813574 4285088604 5648487...

output:

328766632686396

result:

ok "328766632686396"

Test #8:

score: 10
Accepted
time: 298ms
memory: 9892kb

input:

100000 5 50000
2090638820 9317267787 6793358676 4188448984 -9559977197
7940656860 -2874312253 -64757...

output:

526871256881132

result:

ok "526871256881132"

Test #9:

score: 10
Accepted
time: 2276ms
memory: 18768kb

input:

200000 7 150000
9971130068 -8676993799 6080041194 -2943164240 -8998382194 9328104368 -6115122293
-24...

output:

993405245943392

result:

ok "993405245943392"

Test #10:

score: 0
Time Limit Exceeded

input:

200000 8 190000
1307391941 4980087558 -8998121420 3485381411 -4347578759 3621016169 4723154919 80775...

output:


result: