C语言简单实现素数判断,一元二次方程求解,闰年判断,代码如下(运行环境WIN11,Visual studio2022):
#include <stdio.h>
#include <math.h>
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");
}