【信息学奥赛】在一个包含N个整数的数组中找到第一个质数

【信息学奥赛】在一个包含N个整数的数组中找到第一个质数

|-----------------------------|
| 💖The Begin💖点点关注,收藏不迷路💖 |

编写一个函数,用于在一个包含N个整数的数组中找到第一个质数,若有则返回函数的地址;否则返回NULL(空指针)。

输入:

两行,第一行为N,第二行为N个数据元素

输出:

素数的地址和它本身,如果不存在,输出can't find!

样例输入 1:

java 复制代码
4
8 6 9 7

样例输出 1:

java 复制代码
3 7

样例输入 2:

java 复制代码
4
8 6 9 77

样例输出 2:

java 复制代码
can't find!

裁判测试程序样例:

java 复制代码
#include<stdio.h>
#include<math.h>
int n,a[10001];
int isprime(int n){
	int i=0;
	if(n<2)return 1;
	if(n==2)return 0;
	for(i=2;i<=sqrt(n);i++){
		if(n%i==0)return 0;
	}
	return 1;
}
int *find();
int main() {
	int i=1;
	scanf("%d",&n);
	for(;i<=n;++i)
		scanf("%d",a+i);
	int *p=find();
	if(p!=NULL){
		printf("%d %d\n",p-a-1,*p);
	}else{
		printf("can't find!");
	}
	printf("\n");
	return 0;
}
/* 请把您的答案填写在这里 */

int *find() {
    for (int i = 1; i <= n; ++i) {
        if (isprime(a[i])) {
            return &a[i];
        }
    }

    return NULL;
}

这段代码实现的思想是:

  1. 首先定义了一个isprime函数,用于判断一个数是否为质数。如果一个数小于2,直接返回0;如果一个数等于2,返回1;否则从2开始到该数的平方根之间进行遍历,如果能被整除则说明不是质数,返回0,否则返回1。

  2. 然后定义了一个find函数,用于在输入的整数数组中找到第一个质数。通过遍历数组的方式,对每个元素调用isprime函数,如果找到了质数,则返回该质数的地址,否则返回空指针。

  3. main函数中,首先读取输入的整数N,然后依次读取N个整数到数组中。接着调用find函数找到第一个质数,如果找到了,则输出该质数的位置和值,如果没有找到,则输出"can't find!"。

整体来说,这段代码通过定义函数来实现质数判断和查找操作,然后在main函数中调用这些函数完成任务。

|---------------------------|
| 💖The End💖点点关注,收藏不迷路💖 |

相关推荐
微笑尅乐几秒前
三种思路彻底掌握 BST 判断(递归与迭代全解析)——力扣98.验证二叉搜索树
算法·leetcode·职场和发展
闻缺陷则喜何志丹6 分钟前
【动态规划】数位DP的原理、模板(封装类)
c++·算法·动态规划·原理·模板·数位dp
陌路208 分钟前
C语言基础入门阶段
c语言
豆沙沙包?23 分钟前
2025年--Lc194-516. 最长回文子序列(动态规划在字符串的应用,需要二刷)--Java版
java·算法·动态规划
胖咕噜的稞达鸭24 分钟前
二叉树搜索树插入,查找,删除,Key/Value二叉搜索树场景应用+源码实现
c语言·数据结构·c++·算法·gitee
_extraordinary_24 分钟前
Java Spring配置
java·开发语言·spring
showmethetime24 分钟前
基于相空间重构的混沌时间序列预测MATLAB实现
算法
进击的大海贼43 分钟前
QT-C++ 自定义加工统计通用模块
开发语言·c++·qt
Rhys..44 分钟前
JS - npm init
开发语言·javascript·npm
地平线开发者1 小时前
大模型 | VLM 初识及在自动驾驶场景中的应用
算法·自动驾驶