【C++题解】1997. 孤独的素数

欢迎关注本专栏《C++从零基础到信奥赛入门级(CSP-J)》

问题:1997. 孤独的素数

类型:二维数组


题目描述:

在一个 n 行 m 列的矩阵王国中,生活着一些整数,其中一些是素数,一些不是素数。如果一个素数的上下左右、左上、右上、左下、右下相邻的数中都没有素数,我们就认为这是一个孤独的素数。

比如:一个 3 行 5 列的矩阵如下。

cpp 复制代码
3 8 10 9 5
6 10 2 4 13
8 8 9 6 3

这个矩阵中有 2 个素数,分别是第 1 行第 1 列的 3,和第 2 行第 3 列的 2 。

请编程计算出,一个 n 行 m 列的矩阵中有多少个孤独的素数?

输入:

第 1 行有 2 个整数 n 和 m ,代表矩阵的大小(3≤n,m≤50)。

接下来 n 行,每行有 m 个整数(这些整数是 1∼1000 之间的整数,含 1 和 1000 )

输出:

输出 1 个整数,代表矩阵中孤独素数的个数。

样例:

输入:

cpp 复制代码
3 5
3 8 10 9 5
6 10 2 4 13
8 8 9 6 3

输出:

cpp 复制代码
2

完整代码如下:

cpp 复制代码
#include<bits/stdc++.h> 
using namespace std;

bool isPrime(int p){
	if(p<=3) return p>1;
	if(p%2==0||p%3==0) return false;
	for(int i=5;i*i<=p;i+=6){
		if(p%i==0||p%(i+2)==0) return false;
	}
	return true;
}

int main(){
	//一、分析问题
	//已知: 一个 n 行 m 列的矩阵;
	//未知:矩阵中有多少个孤独的素数?
	//关系:
	
	//二、数据定义 
	int n,m,t,c=0;
	bool ip[51][51];
	//三、数据输入 
	cin>>n>>m;
	for(int i=0;i<n;++i){
		for(int j=0;j<m;++j){
			cin>>t;
			ip[i][j]=isPrime(t);
		}
	}
	//四、数据计算 
	for(int i=0;i<n;++i){
		for(int j=0;j<m;++j){
			if(ip[i][j]){
				//上 
				if(i-1>=0&&ip[i-1][j]) continue;
				//右上 
				if(i-1>=0&&j+1<m&&ip[i-1][j+1]) continue;
				//右
				if(j+1<m&&ip[i][j+1]) continue;
				//右下 
				if(i+1<n&&j+1<m&&ip[i+1][j+1]) continue;
				//下 
				if(i+1<n&&ip[i+1][j]) continue;
				//左下 
				if(i+1<n&&j-1>=0&&ip[i+1][j-1]) continue;
				//左 
				if(j-1>=0&&ip[i][j-1]) continue;
				//左上 
				if(i-1>=0&&j-1>=0&&ip[i-1][j-1]) continue;
				
				//八个方向都不是素数 
				++c;
			}
		}
	}

	//五、输出结果 
	cout<<c;
	return 0;	
}
相关推荐
m0_672656541 分钟前
JavaScript性能优化实战技术文章大纲
开发语言·javascript·性能优化
Yang-Never2 分钟前
Android 内存泄漏 -> LiveData如何解决ViewMode和Activity/Fragment之间的内存泄漏
android·java·开发语言·kotlin·android studio
Smartdaili China3 分钟前
如何在桌面和移动设备上修复YouTube错误400
开发语言·php·error·youtube·移动·住宅ip·错误400
持梦远方9 分钟前
持梦行文本编辑器(cmyfEdit):架构设计与十大核心功能实现详解
开发语言·数据结构·c++·算法·microsoft·visual studio
HeDongDong-12 分钟前
Kotlin 协程(Coroutines)详解
android·开发语言·kotlin
阿里嘎多学长12 分钟前
2025-12-29 GitHub 热点项目精选
开发语言·程序员·github·代码托管
鹿角片ljp14 分钟前
深入理解Java集合框架:核心接口与实现解析
java·开发语言·windows
小灰灰搞电子21 分钟前
C++ 文件操作详解
开发语言·c++·文件操作
让学习成为一种生活方式27 分钟前
如何根据过滤的pep序列进一步过滤gff3文件--python015
开发语言·人工智能·python
im_AMBER31 分钟前
Leetcode 90 最佳观光组合
数据结构·c++·笔记·学习·算法·leetcode