【C语言网】基础题集训练详解( 三)
题目目录
前言
C语言编程训练日常,用于记录自身所学,归纳总结。
本次习题用的是vs2022版编译器,差别:将scanf按编译器需求改写成了scanf_s。
一、题目 1004 [递归]母牛的故事
题目:
代码详解:
#include<stdio.h>//求第n年牛的数量(可多组数据测试)
int fun(int n)
{
if(n<=3) return n;
else return fun(n-1)+fun(n-3);
}
int main()
{
int n;
printf("请输入n的值为:\n");
while(scanf_s("%d",&n) && n)
printf("%d\n",fun(n));
return 0;
}
二、题目 1019 [编程入门]自由下落的距离计算
题目:
代码详解:
#include<stdio.h> //自由下落的距离计算
int main()
{
float N, M, h,sum;
printf("请输入M,N的值:");
//M:自由落体的高度,N:球反弹次数
scanf_s("%f%f",&M,&N);
h = M; sum = M;
while (h > 0 && N >1)
{
h = h / 2;
//执行循环第一次此处sum值为碰地两次经过之和
sum = sum +2* h;
//故while循环条件N值减一,碰地次数总和才为N
N--;
}
h = h / 2;//第N次碰地反弹的高度是第N次高度的一半
printf("%0.2f,%0.2f",h, sum);
return 0;
}
三、 题目 1020 [编程入门]猴子吃桃的问题
题目:
代码解析:
#include<stdio.h> //猴子吃桃的问题
int main()
{
int N,sum=1;
scanf_s("%d",&N);
while (--N)
{
sum = (sum + 1) * 2;
}
printf("第一天摘的桃子数为:%d",sum);
return 0;
}
四、 题目 1021 [编程入门]迭代法求平方根
题目:
代码解析:
#include<stdio.h>//迭代法求平方根
#include<math.h>
int main()
{
int a;
float x1 = 1.0, x2=0;
printf("请输入需要计算的数a的值:");
scanf_s("%d",&a);
while (fabs(x1 - x2) > 1e-5)
{
x2 = x1;
x1= (x2 + a / x2) / 2;
}
printf("%0.3f",x1);
return 0;
}
五、题目 1022 [编程入门]筛选N以内的素数
题目:
注意素数判断:判断某数m是否为素数只需用m除于2~√m之间的每一个整数就可以了。如果m取余2~√m任意一个整数值为0,则不为素数,否则为素数。例如判断17是否是素数只需使17除于2~4之间的每个整数去除,由于都不能整除,故17是素数。
代码解析:
#include<stdio.h>//筛选N以内的素数
#include<math.h>
void prime(int M)
{
int i,t=0;
for (i = 2; i <= sqrt(M); i++)
{
if (M %i == 0) t++;
}
if (t == 0) printf("%d是素数\n", M);
return ;
}
int main()
{
int N;
printf("请输入N的值:");
scanf_s("%d",&N);
for (int i=2; i <= N; i++)
{
prime(i);
}
return 0;
}
总结
C语言编程基础,简单运用。