社区讨论

WA0PTSQWQ壶关求条

B3738[信息与未来 2018] 素数方阵参与者 1已保存回复 0

讨论操作

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

当前回复
0 条
当前快照
1 份
快照标识符
@mhizff6v
此快照首次捕获于
2025/11/03 18:13
4 个月前
此快照最后确认于
2025/11/03 18:13
4 个月前
查看原帖
CPP
#include<iostream>
#include<cstring>
using namespace std;
int p[501];
void sieve(int t)
{
	bool isp[501];
	memset(isp,1,sizeof isp);
	isp[1]=0;
	for(int i=2;i*i<=t;i++)
		if(isp[i])
			for(int j=i*i;j<=t;j++)
				isp[j]=0;
	int k=1;
	for(int i=2;i<=t;i++)
		if(isp[i])
			p[k++]=i;
}
int main()
{
	int n,a[101][101];
	cin>>n>>x>>y;
	sieve(n*n);
	int rs=1,re=n,cs=1,ce=n;
	int k=1;
	while(k<=n*n)
	{
		for(int j=cs;j<=ce&&k<=n*n;j++)
			a[rs][j]=p[k++];
		rs++;
		for(int j=rs;j<=re&&k<=n*n;j++)
			a[j][ce]=p[k++];
		ce--;
		for(int j=ce;j>=cs&&k<=n*n;j--)
			a[re][j]=p[k++];
		re--;
		for(int j=re;j>=rs&&k<=n*n;j--)
			a[j][cs]=p[k++];
		cs++;
	}
	cout<<a[x][y];
	return 0;
}

回复

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

正在加载回复...