第五次作业

1. 选择题

题⽬:以下正确的说法是( C)。
A. 定义函数时,形参的类型说明可以放在函数体内。
B. return后边的值不能为表达式。
C. 如果函数值的类型与返回值类型不⼀致,以函数值类型为准。
D. 如果形参与实参类型不⼀致,以实参类型为准。

2. 选择题

题⽬:若调⽤⼀个函数,且此函数中没有return语句,则正确的说法是:该函数(D )。
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));
}

输出“ 9”(前有两个空格)。程序先运行函数(int)fun(a + c, b),返回15,后运行函数fun((int) fun(a + c, b), a - c)),即fun(15,a-c),返回9,%3.0f表示输出3位整数,0位小数,所以最后输出“ 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的正整数的回⽂数数量。
📢 1. 回⽂数是指某数与其反序数相等,如5、131、1551、345676543.
2. 位数为5的正整数,即 [10000, 99999)之间的正整数。

#include<math.h>
#include<stdlib.h>
#include<stdio.h>

int symPalindrome(int n)
{
	int t,i;
	int N = 0;
	int a[100];
	for (t = 0; n > 0; t++) {
		a[t] = n % 10;
		n /= 10;
		if (n == 0) {
			break;
		}
	}
	int T = t;
	for (i = 0; i <= T / 2 - 1; t--, i++) {
		if (a[i] == a[t]) {
			if (i == T / 2 - 1) {
				N = 1;
			}
		}
		else {
			break;
		}
	}
	return N;
}
int main()
{
	int t;
	int n = 0;
	int N = 0;
	for (t = 10000; t < 100000; t++) {
		N = symPalindrome(t);
		if ( N == 1) {
			n++;
		}
	}

	printf("%d", n);
	return 0;
}

在这里插入图片描述

6. 附加题

编写⼀个函数 symPalindrome , 该函数⽤于判断⼀个数是否为对称回⽂数。然后在主函数中使⽤该函数,判断位数为5的正整数的对称回⽂数数量。
📢 对称回⽂数指某数与其平⽅都是回⽂数。例如,n=11时, ;n=111
时, 。
🥰 ⾮必做题。建议⼤家积极思考并尝试编程,做完且正确者有加分!

#include<math.h>
#include<stdlib.h>
#include<stdio.h>

int symPalindrome(int n)
{
	int t,i;
	int N = 0;
	int num = n * n;
	int a[100];
	for (t = 0; n > 0; t++) {
		a[t] = n % 10;
		n /= 10;
		if (n == 0) {
			break;
		}
	}
	int T = t;
	for (i = 0; i <= T / 2 - 1; t--, i++) {
		if (a[i] == a[t]) {
			if (i == T / 2 - 1) {
				N = 1;
			}
		}
		else {
			break;
		}
	}
	return N;
}
int symPalindrome1(int n)
{
	int N = 0;
	int sum = n * n;
	N = symPalindrome(n);
	if (N == 1) {
		N = symPalindrome(sum);
	}
	return N;
}

int main()
{
	int t;
	int n = 0;
	int N = 0;
	for (t = 10000; t < 100000; t++) {
		N = symPalindrome1(t);
		if ( N == 1) {
			n++;
		}
	}
	printf("%d", n);
	return 0;
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值