第一题
- 选择题
题⽬:以下正确的说法是( )。
A. 定义函数时,形参的类型说明可以放在函数体内。
B. return后边的值不能为表达式。
C. 如果函数值的类型与返回值类型不⼀致,以函数值类型为准。
D. 如果形参与实参类型不⼀致,以实参类型为准。
答:C,形参类型说明必须要放在形参前,不能在函数体内;return后的值既能是常量和变量,也能是表达式;编译器会自动将实参类型转换去匹配形参类型。
第二题
- 选择题
题⽬:若调⽤⼀个函数,且此函数中没有return语句,则正确的说法是:该函数(
)。
A. 没有返回值
B. 返回若⼲个系统默认值
C. 能返回⼀个⽤户所希望的值
D. 返回⼀个不确定的值
答:A,return都没了哪来的返回值。
第三题
- 填空题
题⽬:有以下程序,程序运⾏后的输出结果是( )。需附上简要解释。
float fun(int x, int y) {
return (x + y);
}
void main() {
int a = 2,b = 5,c = 8;
printf(“%3.0f\n”, fun((int) fun(a + c, b), a - c));
}
答:9,fun(a + c, b)得15,然后fun((int) fun(a + c, b), a - c))意为15+(-6)得9,然后因为3.0f,输出不带小数点。
第四题
题⽬:有以下程序,程序运⾏后的输出结果是( )。
int f (int n)
{
if (n == 1) return 1;
else return f(n - 1) + 1;
}
void main()
{
int i, j = 0;
for (i = 1; i < 3; i++) j += f (i);
printf (“%d\n”, j);
}
📢 本题涉及递归函数的概念,下周会讲到这个话题,但现有课程知识⼤家⾜以推
出答案,来试⼀试
答:3,进入for循环i=1得f(1)=1,j就等于0+f(1)=1,再进行循环i=2,此时f(2)=f(1)+1=2,从而j=1+f(2)=3。
第五题
编写⼀个函数 palindrome , 该函数⽤于判断⼀个数是否是回⽂数。然后在主函数中使
⽤该函数,判断位数为5的正整数的回⽂数数量。
📢 1. 回⽂数是指某数与其反序数相等,如5、131、1551、345676543.
2. 位数为5的正整数,即 之间的正整数。
#include<stdio.h>
int palindrome(int num);
int palindrome(int num)
{
int flag=0;
if(num<=0&&num%10==0)//这些数一定不是回文数
{
return 0;
}
if(num>0&&num<10)//个位数都是回文数
{
return 1;
}
int div=1;
int left=0;
int right=0;
while(num/div>=10) div*=10;
while(num>0)
{
left=num/div;//得左边的数
right=num%10;//得右边的数
if(left!=right)
{
return 0;
}
num=(num%div)/10;
div/=100;//被除数少了2位 ,除数也要缩小 100倍
}
return 1;
}
int main()
{
int i;
int count=0;
for(i=10000;i<100000;i++)
{
if(palindrome(i))
{
count++;
}
}
printf("位数为5的正整数的回文数数量为:%d",count);
return 0;
}