QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#646257#9457. Prime Setgoj_bot1AC ✓75ms16656kbC++142.5kb2024-10-16 21:57:552024-10-16 21:57:55

Judging History

你现在查看的是最新测评结果

  • [2024-10-16 21:57:55]
  • 评测
  • 测评结果:AC
  • 用时:75ms
  • 内存:16656kb
  • [2024-10-16 21:57:55]
  • 提交

answer

#include<bits/stdc++.h>
#define mod 998244353ll
#define pii pair<int,int>
#define fi first
#define se second
#define mems(x,y) memset(x,y,sizeof(x))
#define pb push_back
#define db double
using namespace std;
const int maxn=3010;
const int maxm=2000010;
const int inf=1e18;
inline int read(){
	int x=0,f=1;
	char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch-48);ch=getchar();}
	return x*f;
}
bool Mbe;

int pre[maxm],cnt;
bool vis[maxm];
void init(int n){
	for(int i=2;i<=n;i++){
		if(!vis[i])pre[++cnt]=i;
		for(int j=1;j<=cnt&&i*pre[j]<=n;j++){
			vis[i*pre[j]]=1;
			if(i%pre[j]==0)break;
		}
	}
}
int n,k,a[maxn];
int head[maxn],tot=1;
struct nd{
	int nxt,to,w;
}e[maxn*maxn];
void add(int u,int v,int w){
	// cout<<u<<" "<<v<<" "<<w<<"\n";
	e[++tot]={head[u],v,w};head[u]=tot;
	e[++tot]={head[v],u,0};head[v]=tot;
}
int s,t,flow;
int rad[maxn],dis[maxn];
bool bk[maxn];
int dfs(int u,int res){
	if(u==t)return res;
	int cnt=0;
	for(int i=rad[u];i;i=e[i].nxt){
		int v=e[i].to;rad[u]=i;if(bk[v])continue;
		if(e[i].w&&dis[v]==dis[u]+1){
			int out=dfs(v,min(e[i].w,res));
			e[i].w-=out,e[i^1].w+=out;
			cnt+=out,res-=out;
			if(!res)break;
		}
	}
	return cnt;
}
queue<int> q;
bool bfs(){
	for(int i=1;i<=t;i++)rad[i]=head[i],dis[i]=0;
	dis[s]=1,q.push(s);
	while(!q.empty()){
		int u=q.front();q.pop();
		// cout<<u<<" "<<dis[u]<<endl;
		for(int i=head[u];i;i=e[i].nxt){
			int v=e[i].to;if(bk[v])continue;
			if(e[i].w&&!dis[v]){
				dis[v]=dis[u]+1;
				q.push(v);
			}
		}
	}
	return dis[t];
}
void work(){
	n=read();k=read();
	for(int i=1;i<=n;i++)a[i]=read();
	for(int i=1;i<=n+2;i++)head[i]=0;tot=1;
	int cnt=0,sum=0;
	s=n+1,t=n+2;
	for(int i=1;i<=n;i++){
		for(int j=1;j<i;j++)if(!vis[a[i]+a[j]]){
			bk[i]=bk[j]=1;
			if(a[i]==1&&a[j]==1)continue;
			if(a[i]&1)add(i,j,1);
			else add(j,i,1);
		}
		if(a[i]&1)add(s,i,1);
		else add(i,t,1);
	}
	for(int i=1;i<=n;i++)if(bk[i])++sum,bk[i]=0;
	for(int i=1;i<=n;i++)if(a[i]==1)bk[i]=1,++cnt;
	int flow=0;
	while(bfs())flow+=dfs(s,inf);
	for(int i=1;i<=n;i++)if(a[i]==1)bk[i]=0;
	int num=0;
	while(bfs())num+=dfs(s,inf);
	flow+=num;
	// cout<<flow<<" "<<num<<" "<<cnt<<" "<<sum<<"\n";
	if(k<=flow)printf("%lld\n",k*2);
	else{
		if(k-flow<=(cnt-num)/2)printf("%lld\n",k*2);
		else printf("%lld\n",min(sum,flow*2+(cnt-num)/2*2+k-flow-(cnt-num)/2));
	}
}

// \
444

bool Med;
int T;
signed main(){
	T=read();init(maxm-10);
	while(T--)work();
}

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

詳細信息

Test #1:

score: 100
Accepted
time: 4ms
memory: 6352kb

input:

4
4 2
2 3 4 5
5 3
3 4 12 3 6
6 3
1 3 6 8 1 1
1 0
1

output:

4
3
6
0

result:

ok 4 lines

Test #2:

score: 0
Accepted
time: 75ms
memory: 16656kb

input:

110
3 3
2 2 2
3 1
1 1 1
3 2
1 1 1
3 3
1 1 1
4 2
1 1 1 1
10 7
1 1 1 2 4 6 8 10 12 14
18 1
10 5 9 4 10 7 2 4 9 1 6 1 4 9 2 4 9 7
19 5
1 6 1 8 8 1 5 10 9 2 10 2 1 9 6 10 4 3 6
14 4
6 6 8 9 5 3 4 9 2 2 1 10 10 1
15 10
5 4 2 4 10 1 8 4 10 3 10 3 7 10 4
17 5
10 7 2 4 3 1 10 8 2 8 3 4 1 1 1 1 1
20 6
8 4 6 ...

output:

0
2
3
3
4
8
2
10
8
15
10
12
10
10
12
16
10
10
12
16
14
13
13
14
17
0
19
12
12
11
16
10
19
2
12
10
5
14
10
10
13
2
18
2
4
4
11
8
11
8
0
10
10
0
10
0
8
15
12
11
13
18
10
17
9
8
20
19
13
6
4
6
11
9
13
11
6
2
8
12
17
14
6
2
20
2
18
17
6
2
10
0
7
16
2
2
0
2
18
14
11
8
4
6
0
19
890
204
2746
2372

result:

ok 110 lines

Extra Test:

score: 0
Extra Test Passed