蓝桥杯(等差素数列,C++)

思路:

1、因为找的是长度为10,且公差最小的等差素数列,直接用枚举即可。

2、枚举用三重循环,第一重枚举首项,第二重枚举公差,第三重因为首项算一个,所以枚举九个等差素数。

代码:

cpp 复制代码
#include<iostream>
using namespace std;
int sushu(int n)//判断是否为素数
{
	for (int i = 2; i < n / 2; i++)
		if (n % i == 0)//不是素数
			return 0;
	return 1;
}
int main()
{
	int flag = 1;//计数
	for (int i = 2; i < 10000; i++)//枚举首项
	{
		if (sushu(i))
		{
			for (int j = 2; j < 1000; j++)//枚举公差
			{
				for (int k = 1; k < 10; k++)//本身算一个,再找九个数
				{
					if (sushu(i + j * k))
						flag++;
					else
					{
						flag = 1;
						break;
					}
				}
				if (flag == 10)
				{
					cout << j;
					break;
				}
			}
		}
	}
}
相关推荐
zmzb01037 分钟前
C++课后习题训练记录Day104
开发语言·c++
honiiiiii20 分钟前
SMU winter week4
c++
zmzb01031 小时前
C++课后习题训练记录Day105
开发语言·c++·算法
得一录1 小时前
AI面试·高难度题
人工智能·面试·职场和发展
闻缺陷则喜何志丹1 小时前
【拆位法】P8743 [蓝桥杯 2021 省 A] 异或数列|普及+
c++·蓝桥杯·位运算·拆位法
fpcc1 小时前
跟我学C++中级篇——Concepts的循环依赖
c++·模板和元编程
programhelp_2 小时前
2026 Adobe面试全流程拆解|OA/VO/Onsite实战指南+高频考点避坑
adobe·面试·职场和发展
訫悦2 小时前
C++自带的set get语法(MSVC)
开发语言·c++
墨雪不会编程2 小时前
C++之【list详解篇一】如何玩好链表
c++·链表·list
柏木乃一2 小时前
Linux进程信号(2):信号产生part2
linux·运维·服务器·c++·信号处理·信号·异常