1. 选择题
题⽬:以下正确的说法是( C )。
A. 定义函数时,形参的类型说明可以放在函数体内。
B. return后边的值不能为表达式。
C. 如果函数值的类型与返回值类型不⼀致,以函数值类型为准。
D. 如果形参与实参类型不⼀致,以实参类型为准。
2. 选择题
题⽬:若调⽤⼀个函数,且此函数中没有return语句,则正确的说法是:该函数(A)。
A. 没有返回值
B. 返回若⼲个系统默认值
C. 能返回⼀个⽤户所希望的值
D. 返回⼀个不确定的值
3. 填空题
题⽬:有以下程序,程序运⾏后的输出结果是(---9 )。需附上简要解释。
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));
}
简述:第一个次调用函数fun(a + c, b)=15;第二次调用fun((int) fun(a + c,b), a - c))为fun(15,-6),结果为整形且要输出三位数,数不够空格来凑;---9;
4. 填空题
题⽬:有以下程序,程序运⾏后的输出结果是( 3 )。
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);
}
5. 编程题
编写⼀个函数 palindrome , 该函数⽤于判断⼀个数是否是回⽂数。然后在主函数中使
⽤该函数,判断位数为5的正整数的回⽂数数量。
#include<stdio.h>
long int palindrome (int n){
int a,b,c,d,e;
//int n;
int count=0;
a=n%10;
b=n/10%10;
c=n/100%10;
d=n/1000%10;
e=n/10000%10;
if(a==e&&b==d){
count++;}
return count;
}
int main()
{
int m;
int n;
int i;
int count=0;
int k=0;
scanf("%d %d",&m,&n);
for(i=m;i<n;i++)
{
//k=palindrome(i);
k+=palindrome(i);
//if (palindrome(i)==1)
//count++;
}
printf("%d",k);
return 0;
}
题目是开区间不包括99999本身;
6. 附加题
编写⼀个函数 symPalindrome , 该函数⽤于判断⼀个数是否为对称回⽂数。然后在主函
数中使⽤该函数,判断位数为5的正整数的对称回⽂数数量。
#include <stdio.h>
long int Palindrome(int n);
long int symPalindrome(int n);
int main()
{
int m=10000;
int n=99999;
int i=0;
int count=0;
//scanf("%d %d",&m,&n);
for(i=m;i<n;i++)
{
if(symPalindrome(i)){
count++;
}
}
printf("%d\n",count);
return 0;
}
long int Palindrome(int n)
{
int tmp,sum=0;
int num;
num=n;
int count=0;
for( ;n!=0;n/=10){
tmp=n%10;
sum=sum*10+tmp; //计算出倒数
}
if (sum==num)
{
return 1;
}else
return 0;
}
long int symPalindrome(int n)
{
int k=n*n;
return Palindrome(n)&&Palindrome(k);
}