C语言简单实现素数判断,一元二次方程求解,闰年判断

C语言简单实现素数判断,一元二次方程求解,闰年判断,代码如下(运行环境WIN11,Visual studio2022):

#include 
#include 
int main()
{
	float QuadraticEquation();
	float primeNumber();
	float LeapYear();
	int m;
	char n;
	n = 'n';
	while (n == 'n')
	{
		printf("请选择功能,1:求解一元二次方程;2:判断是否为素数;3:判断是否为闰年。\n");
		scanf("%d", &m);//功能选择1,2,3
		if (m == 1)
			QuadraticEquation();//解方程
		else if (m == 2)
			primeNumber();//判断素数
		else if (m == 3)
			LeapYear();
		printf("是否退出程序?请选择:y/n\n");
		rewind(stdin);//清楚缓存
		scanf("%c", &n);
	}
	printf("程序结束!\n");
	return 0;
}

float QuadraticEquation()//一元二次方程函数
{
	float a, b, c, d;
	printf("请输入方程系数:");
	scanf("%f %f %f", &a, &b, &c);//系数输入
	d = b * b - 4 * a * c;
	if (a == 0)//a为零
		if (b != 0)
			printf("x=%f\n", -c / b);//一元一次方程
		else if (c == 0)
			printf("方程有无穷解!\n");
		else
			printf("输入系数有误,方程无解!\n");
	else if (d >= 0)
		printf("x1=%f,x2=%f\n", (-b + sqrt(d)) / 2 / a, (-b - sqrt(d)) / 2 / a);//解方程
	else
		printf("x1=%f+%f*i,x2=%f%f*i\n", -b / 2 / a, sqrt(-d) / 2 / a, -b / 2 / a, -sqrt(-d) / 2 / a);//虚数
}

float primeNumber()//素数判断函数
{
	printf("请输入数字:");
	float a, c, i, j;
	j = 1;
	scanf("%f", &a);
	c = (int)a;
	if (a <= 1 || c != a)//小数与小于等于1的整数
	{
		printf("此数不是素数!\n");
		j = 0;
	}
	else 
		for (i = 1; i <= sqrt(a);i++)
		{
			if (a == i * i)
			{
				printf("此数不是素数!\n");
				j = 0;
				break;
			}
		}
	if (j == 1)
		printf("此数为素数!\n");
}

float LeapYear()//闰年判断函数
{
	printf("请输入年份:");
	float a;
	int c;
	scanf("%f", &a);
	c = (int)a;
	if (c != a || a <= 0)
		printf("输入数据有误,请输入正整数!\n");
	else if (c % 4 == 0 && c % 100 != 0 || c % 400 == 0)//能被4整除且不能被100整除与能被400整除
		printf("此年份为闰年!\n");
	else
		printf("此年份不是闰年!\n");
}

你可能感兴趣的:(C语言,c语言,开发语言,数据分析,数学,学习方法)