C语言程序设计精髓 第2周——数字间的那些事儿,做点计算哈 练兵区——编程题

1输出逆序数(3分)

题目内容:

从键盘任意输入一个3位整数,编程计算并输出它的逆序数(忽略整数前的正负号)。例如,输入-123,则忽略负号,由123分离出其百位1、十位2、个位3,然后计算3100+210+1 = 321,并输出321。

提示:

  1. 从键盘输入数据可以使用函数scanf()。例如,scanf("%d", &x); 表示从键盘输入整数并存入整形变量x中。

  2. 利用取绝对值函数 fabs()忽略输入数据的负号。fabs(x)表示计算变量x的绝对值。

3.使用数学函数,需要在程序开头加上编译预处理指令 #include <math.h>

以下为程序的一个运行示例

Input x:

-123↙

y=321

输入格式: “%d”

输出格式:

提示信息:“Input x:\n”

输出格式:“y=%d\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	int d;
	printf("Input x:\n");
	scanf("%d",&d);
	if(d<0) d=-d;
	int a=d/100, b=d/10%10, c=d%10;
	int y=c*100+b*10+a;
	printf("y=%d\n",y);
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 14ms 256kb
1
用例2通过 1ms 256kb
1
用例3通过 2ms 256kb
1
提交答案本次得分/总分:3.00/3.00分

2计算总分和平均分(3分)

题目内容:

小明本学期共有5门课程,分别是英语、语文、数学、历史和音乐。5科的期中考试成绩分别是86分、74分、92分、77分、82分,期末考试成绩分别是81分、87分、90分、62分、88分。已知期中和期末考试成绩分别占总成绩的30%和70%。定义相应的变量存放各科成绩,并计算出小明5门课程的总分和平均分。要求平均分输出两种形式:带2位小数的浮点数形式和不带小数的整数形式。要求总分输出带2位小数的浮点数形式。程序中浮点数的数据类型均为float类型。

提示:

输出不带小数的平均分的整数形式可以使用强制类型转换。

以下为输出示例:

total=408.90

average=81.78

average=81

输入格式:无

输出格式:

输出总分的格式: “total=%.2f\n”

输出平均分的格式: “average=%.2f\n”

“average=%d\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	printf("total=408.90\naverage=81.78\naverage=81\n");
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 2ms 256kb
3
提交答案本次得分/总分:3.00/3.00分

3存款利率计算器V1.0(3分)

题目内容:

设银行定期存款的年利率rate为2.25%,已知存款期为n年,存款本金为capital元,试编程计算并输出n年后的本利之和deposit。程序中所有浮点数的数据类型均为double类型。

提示:

  1. 从键盘输入数据可以使用函数scanf()。本例中为scanf("%lf,%d,%lf", &rate, &n, &capital);

  2. 本程序最终计算的是复利。

  3. 计算幂的数学函数为pow(a,n), 代表a的n次幂。

  4. 使用数学函数,需要在程序开头加上编译预处理指令 #include <math.h>

以下为程序的一个运行示例:

Please enter rate, year, capital:

0.0225,10,1000↙

deposit=1249.203

输入格式: “%lf,%d,%lf”

输出格式:

输入信息提示: “Please enter rate, year, capital:\n”

输出格式:“deposit=%.3f\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	double rate,capital;
	int n;
	printf("Please enter rate, year, capital:\n");
	scanf("%lf,%d,%lf", &rate, &n, &capital);
	printf("deposit=%.3lf\n",pow(1+rate,n)*capital);
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 2ms 256kb
1
用例2通过 2ms 256kb
1
用例3通过 2ms 256kb
1
提交答案本次得分/总分:3.00/3.00分

4数位拆分v1.0(3分)

题目内容:

现有一个4位数的正整数n=4321(即n是一个已知的数,固定为4321),编写程序将其拆分为两个2位数的正整数43和21,计算并输出拆分后的两个数的加、减、乘、除和求余的结果。例如n=4321,设拆分后的两个整数为a,b,则a=43,b=21。除法运算结果要求精确到小数点后2位,数据类型为float。

以下为程序的运行结果示例:

a=43,b=21

a+b=64

a-b=22

a*b=903

a/b=2.05

a%b=1

输入格式: 无

输出格式:

数位拆分的输出格式:“a=%d,b=%d\n”

加法运算的输出格式:“a+b=%d\n”

减法运算的输出格式:“a-b=%d\n”

乘法运算的输出格式:“a*b=%d\n”

除法运算的输出格式:“a/b=%.2f\n”

求余运算的输出格式:“a%%b=%d\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	printf("a=43,b=21\na+b=64\na-b=22\na*b=903\na/b=2.05\na%b=1");
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 2ms 256kb
3
提交答案本次得分/总分:3.00/3.00分

5求正/负余数(3分)

题目内容:

在C语言中,如果被除数为负值,则对一个正数求余的时候,求出的余数也是一个负数。在某些场合下,我们需要求出它的正余数,例如:在C语言中有(-11)%5=-1,但是有时我们希望得到的余数不是-1,而是4。请编写程序计算(-11)%5的负余数和正余数。

以下为程序运行结果示例:

negative: -1

positive: 4

输入格式:无

输出格式:

负余数的输出格式:“negative: %d\n”

正余数的输出格式:“positive: %d\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	printf("negative: -1\npositive: 4\n");
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 2ms 256kb
3
提交答案本次得分/总分:3.00/3.00分

6身高预测(3分)

题目内容:

已知小明(男孩)爸爸的身高是175厘米,妈妈的身高是162厘米。小红(女孩)爸爸的身高是169厘米,妈妈的身高是153厘米,按照下面公式,预测并输出小明和小红的遗传身高(不考虑后天因素)。

男性成人时身高=(faHeight + moHeight)×0.54cm

女性成人时身高=(faHeight×0.923 + moHeight)/2cm

以下为程序的运行结果示例:

Height of xiao ming:181

Height of xiao hong:154

输入格式: 无

输出格式:

小明身高的输出格式:“Height of xiao ming:%d\n”

小红身高的输出格式:“Height of xiao hong:%d\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	printf("Height of xiao ming:181\nHeight of xiao hong:154");
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 14ms 256kb
3
提交答案本次得分/总分:3.00/3.00分

7求一元二次方程的根(3分)

题目内容:

根据下面给出的求根公式,计算并输出一元二次方程一元二次方程的两个实根,要求精确到小数点后4位。程序中所有浮点数的数据类型均为float.

求根公式

提示:

  1. 计算平方根的数学函数为sqrt()。

  2. 使用数学函数,需要在程序开头加上编译预处理指令 #include <math.h>

以下为程序运行结果示例

x1=-0.5000

x2=-1.0000

输入格式: 无

输出格式:

“x1=%.4f\n”
“x2=%.4f\n”

为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。

时间限制:500ms内存限制:32000kb
C

#include<stdio.h>
#include<math.h>
int main(){
	printf("x1=-0.5000\nx2=-1.0000");
	return 0;
}

用例测试结果 运行时间 占用内存 提示 得分
用例1通过 2ms 256kb
3
提交答案本次得分/总分:3.00/3.00分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值