当前位置: 首页 > news >正文

C/C++ 实现由用户通过键盘输入自然数并判断其是不是素数(带清空缓冲区等考虑)

由键盘输入一个自然数并判断其是不是素数是一个老生常谈的话题了。对新手程序员而言,这个题目估计也是一道必做题。这里分享一个 C 语言风格和一个 C++ 风格的代码,仅提供参考和交流,不适合新生直接复制去交作业

与常规代码(指一般用于新生交作业的以 sqrt(n) 作为循环中止条件的代码)的不同:

  1. 使用循环,在 C++ 中用 for (;;) 进行无条件死循环;
  2. 每次接收输入前清空缓冲区(不适合 ACM 场景)防止残留的键盘缓冲区影响下一次输入甚至造成不明原因的死循环;
  3. C 语言:使用 scanf_s 而非 scanf,因为更加安全,且 scanf_s 返回 1 可以指示输入成功,避免在需要接收一个数字类型的时候受到非数字字符的干扰或甚至造成不明原因的死循环;
  4. C++:手动判断字符串是否为纯数字字符且是否越出 unsigned long long int 的承受范围,相比于这里提供的 C 语言风格代码更友好。

C 语言风格:

#include<stdio.h>
#include<math.h>

static bool isPrime(int n)
{
	for (int i = 2; i <= sqrt(n); ++i)
		if (0 == n % i)
			return false;
	return true;
}

int main()
{
	int n = 2;
	rewind(stdin);
	fflush(stdin);
	printf("请输入一个正整数:");
	while (scanf_s("%d", &n) == 1)
	{
		if (n <= 0)
			printf("%d 小于等于 0,本程序仅支持正整数。\n", n);
		else if (1 == n)
			printf("%d 既不是素数也不是合数。\n", n);
		else if (isPrime(n))
			printf("%d 是素数。\n", n);
		else
			printf("%d 不是素数。\n", n);
		rewind(stdin);
		fflush(stdin);
		printf("请输入一个正整数:");
	}
	printf("检测到非数字字符,程序退出。\n\n");
	return 0;
}

C++ 风格:

#include<iostream>
#include<string>
using namespace std;

static bool isDigit(const string& s)
{
	for (size_t i = 0; i < s.length(); ++i)
		if (s[i] < '0' || s[i] > '9')
			return false;
	return true;
}

static bool isPrime(unsigned long long int n)
{
	for (unsigned long long int i = 2; i <= sqrt(n); ++i)
		if (0 == n % i)
			return false;
	return true;
}

int main()
{
	for (;;)
	{
		cout << "请输入一个正整数:";
		rewind(stdin);
		fflush(stdin);
		string s = "";
		getline(cin, s);
		if ((s.length() <= 19 || s.length() == 20 && s.compare("18446744073709551615") <= 0) && isDigit(s))
		{
			const unsigned long long int n = stoull(s);
			if (n <= 1)
				cout << n << " 既不是素数也不是合数。" << endl << endl;
			else if (isPrime(n))
				cout << n << " 是素数。" << endl << endl;
			else
				cout << n << " 不是素数。" << endl << endl;
		}
		else
			break;
	}
	cout << "检测到非数字字符或输入的不是小于等于 18446744073709551615 的自然数,程序退出。" << endl << endl;
	return EXIT_SUCCESS;
}

效果图

相关文章:

  • 【MySQL-数据类型】数据类型分类+数值类型+文本、二进制类型+String类型
  • 全星FMEA软件:汽车电子行业研发管理高效之选
  • VPS加装前置代理全解析
  • uni_app实现下拉刷新
  • K8S学习之基础十七:k8s的蓝绿部署
  • AUTOSAR ETH模块(3)——接口功能分析
  • 利用EasyCVR平台打造化工园区视频+AI智能化监控管理系统
  • 解密 Atlassian Cloud:创新驱动的项目管理之道
  • STM32之I2C通信概览
  • 什么是 spring 的循环依赖?
  • 深入解析EfficientNet:高效深度学习网络与ResNet的对比(使用TensorFlow进行代码复现,并使用cifar10数据集进行实战)
  • UniApp 运行的微信小程序如何进行深度优化
  • 服务器虚拟化:技术原理、实践与未来趋势
  • 测试用大模型组词
  • 文件传输协议(File Transfer Protocol, FTP)
  • 计算机组成原理 第三章 存储系统
  • 机试准备第11天
  • HarmonyOS ArkTS声明式UI开发实战教程
  • Ascend开发板镜像烧录、联网、其他设备访问
  • Laya中runtime的用法
  • 天津建设工程招标信息网官网/新塘网站seo优化
  • wordpress会员插件大全/徐州seo网站推广
  • 做网站界面用什么软件/常州seo
  • 口碑营销的前提及好处有哪些/做seo需要用到什么软件
  • 内江市网站建设/长沙哪里有网站推广优化
  • 网站访问过程/站长统计是什么意思