实验2-1-1 计算摄氏温度
本题要求编写程序,计算华氏温度100°F对应的摄氏温度。计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型。
输入格式:
本题目没有输入。
输出格式:
按照下列格式输出
fahr = 100, celsius = 计算所得摄氏温度的整数值
#include
int main(){
int fahr=100,celsius;
celsius=5*(fahr-32)/9;
printf("fahr = %d, celsius = %d",fahr,celsius);
}
实验2-1-2 温度转换
本题要求编写程序,计算华氏温度150°F对应的摄氏温度。计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型。
输入格式:
本题目没有输入。
输出格式:
按照下列格式输出
fahr = 150, celsius = 计算所得摄氏温度的整数值
#include
int main(){
int fahr=150,celsius;
celsius=5*(fahr-32)/9;
printf("fahr = %d, celsius = %d",fahr,celsius);
}
实验2-1-3 计算物体自由下落的距离
一个物体从100米的高空自由落下。编写程序,求它在前3秒内下落的垂直距离。设重力加速度为10米/秒2。
输入格式:
本题目没有输入。
输出格式:
按照下列格式输出
height = 垂直距离值
结果保留2位小数。
#include
int main(){
int h=100,g=10,t=3;
float height;
height=g*t*t/2.0;
printf("height = %.2f",height);
}
实验2-1-4 计算平均分
已知某位学生的数学、英语和计算机课程的成绩分别是87分、72分和93分,求该生3门课程的平均成绩(结果按整型输出)。
输入格式:
本题无输入
输出格式:
按照下列格式输出结果:
math = 87, eng = 72, comp = 93, average = 计算所得的平均成绩
#include
int main(){
int math = 87, eng = 72, comp = 93,average;
average=(math+eng+comp)/3;
printf("math = %d, eng = %d, comp = %d, average = %d",math,eng,comp,average);
}
实验2-1-5 将x的平方赋值给y
假设x的值为3,计算x的平方并赋值给y,分别以“y = x ∗ x”和“x ∗ x = y”的形式输出x和y的值。
输入格式:
本题无输入
输出格式:
按照下列格式输出代入x=3的结果:
y = x * x
x * x = y
#include
int main(){
int x=3,y;
y=x*x;
printf("%d = %d * %d\n",y,x,x);
printf("%d * %d = %d",x,x,y);
}
实验2-1-6 计算华氏温度
本题要求编写程序,计算摄氏温度26°C 对应的华氏温度。计算公式:F=9×C/5+32,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型。
输入格式:
本题目没有输入。
输出格式:
按照下列格式输出
celsius = 26, fahr = 对应的华氏温度整数值
#include
int main(){
int celsius=26,fahr;
fahr=9*celsius/5+32;
printf("celsius = %d, fahr = %d",celsius,fahr);
}
实验2-1-7 整数152的各位数字
本题要求编写程序,输出整数152的个位数字、十位数字和百位数字的值。
输入格式:
本题无输入。
输出格式:
按照以下格式输出:
152 = 个位数字 + 十位数字10 + 百位数字100
#include
int main(){
int x = 152;
int a = x%10;//个位
int b = x/10%10;//十位
int c = x/100;//百位
printf("%d = %d + %d*10 + %d*100",x,a,b,c);
}
实验2-2-1 计算分段函数[1]
本题目要求计算下列分段函数f(x)的值:
输入格式:
输入在一行中给出实数x。
输出格式:
在一行中按“f(x) = result”的格式输出,其中x与result都保留一位小数。
输入样例1:
10
输出样例1:
f(10.0) = 0.1
输入样例2:
0
输出样例2:
f(0.0) = 0.0
#include
int main(){
double x;
double result;
scanf("%lf",&x);
if(x==0){
result=0;
}else{
result=1/x;
}
printf("f(%.1f) = %.1f",x,result);
}
实验2-2-2 计算摄氏温度
给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C=5×(F−32)/9。题目保证输入与输出均在整型范围内。
输入格式:
输入在一行中给出一个华氏温度。
输出格式:
在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。
输入样例:
150
输出样例:
Celsius = 65
#include
int main(){
int F,Celsius;
scanf("%d",&F);
Celsius=5*(F-32)/9;
printf("Celsius = %d",Celsius);
}
实验2-2-3 计算存款利息
本题目要求计算存款利息,计算公式为interest=money×(1+rate)year−money,其中interest为存款到期时的利息(税前),money是存款金额,year是存期,rate是年利率。
输入格式:
输入在一行中顺序给出三个正实数money、year和rate,以空格分隔。
输出格式:
在一行中按“interest = 利息”的格式输出,其中利息保留两位小数。
输入样例:
1000 3 0.025
输出样例:
interest = 76.89
#include
#include
int main(){
int money;
double year,rate,interest;
scanf("%d %lf %lf",&money,&year,&rate);
interest=money*pow((1+rate),year)-money;
printf("interest = %.2f",interest);
}
实验2-2-4 计算分段函数[2]
本题目要求计算下列分段函数f(x)的值:
注:可在头文件中包含math.h,并调用sqrt函数求平方根,调用pow函数求幂。
输入格式:
输入在一行中给出实数x。
输出格式:
在一行中按“f(x) = result”的格式输出,其中x与result都保留两位小数。
输入样例1:
10
输出样例1:
f(10.00) = 3.16
输入样例2:
-0.5
输出样例2:
f(-0.50) = -2.75
#include
#include
int main(){
double x,result;
scanf("%lf",&x);
if(x>=0){
result=sqrt(x);
}else{
result=pow((x+1),2)+2*x+1/x;
}
printf("f(%.2f) = %.2f",x,result);
}
实验2-2-5 求整数均值
本题要求编写程序,计算4个整数的和与平均值。题目保证输入与输出均在整型范围内。
输入格式:
输入在一行中给出4个整数,其间以空格分隔。
输出格式:
在一行中按照格式“Sum = 和; Average = 平均值”顺序输出和与平均值,其中平均值精确到小数点后一位。
输入样例:
1 2 3 4
输出样例:
Sum = 10; Average = 2.5
#include
int main(){
int a,b,c,d;
int Sum;
double Average;
scanf("%d %d %d %d",&a,&b,&c,&d);
Sum = a+b+c+d;
Average = Sum/4.0;
printf("Sum = %d; Average = %.1f",Sum,Average);
}
实验2-2-6 计算分段函数[3]
本题目要求计算下列分段函数f(x)的值:
输入格式:
输入在一行中给出实数x。
输出格式:
在一行中按“f(x) = result”的格式输出,其中x与result都保留一位小数。
输入样例1:
10
输出样例1:
f(10.0) = 0.1
输入样例2:
234
输出样例2:
f(234.0) = 234.0
#include
int main(){
double x,result;
scanf("%lf",&x);
if(x==10){
result=1/x;
}else{
result=x;
}
printf("f(%.1f) = %.1f",x,result);
}
实验2-2-7 整数四则运算
本题要求编写程序,计算2个正整数的和、差、积、商并输出。题目保证输入和输出全部在整型范围内。
输入格式:
输入在一行中给出2个正整数A和B。
输出格式:
在4行中按照格式“A 运算符 B = 结果”顺序输出和、差、积、商。
输入样例:
3 2
输出样例:
3 + 2 = 5
3 - 2 = 1
3 * 2 = 6
3 / 2 = 1
#include
int main(){
int a,b;
scanf("%d %d",&a,&b);
printf("%d + %d = %d\n",a,b,a+b);
printf("%d - %d = %d\n",a,b,a-b);
printf("%d * %d = %d\n",a,b,a*b);
printf("%d / %d = %d",a,b,a/b);
}
实验2-2-8 阶梯电价
为了提倡居民节约用电,某省电力公司执行“阶梯电价”,安装一户一表的居民用户电价分为两个“阶梯”:月用电量50千瓦时(含50千瓦时)以内的,电价为0.53元/千瓦时;超过50千瓦时的,超出部分的用电量,电价上调0.05元/千瓦时。请编写程序计算电费。
输入格式:
输入在一行中给出某用户的月用电量(单位:千瓦时)。
输出格式:
在一行中输出该用户应支付的电费(元),结果保留两位小数,格式如:“cost = 应付电费值”;若用电量小于0,则输出"Invalid Value!"。
输入样例1:
10
输出样例1:
cost = 5.30
输入样例2:
100
输出样例2:
cost = 55.50
#include
int main(){
int x;
double cost;
scanf("%d",&x);
if(x<0){
printf("Invalid Value!");
}else{
if(x<=50){
cost=0.53*x;
}else{
cost=0.53*50+(x-50)*0.58;
}
printf("cost = %.2f",cost);
}
}
实验2-2-9 计算火车运行时间
本题要求根据火车的出发时间和达到时间,编写程序计算整个旅途所用的时间。
输入格式:
输入在一行中给出2个4位正整数,其间以空格分隔,分别表示火车的出发时间和到达时间。每个时间的格式为2位小时数(00-23)和2位分钟数(00-59),假设出发和到达在同一天内。
输出格式:
在一行输出该旅途所用的时间,格式为“hh:mm”,其中hh为2位小时数、mm为2位分钟数。
输入样例:
1201 1530
输出样例:
03:29
#include
int main(){
int start,end;
scanf("%d %d",&start,&end);
int start_h=start/100;
int start_m=start%100;
int end_h=end/100;
int end_m=end%100;
int time=end_h*60+end_m-(start_h*60+start_m);
int h=time/60;
int m=time%60;
printf("%02d:%02d",h,m);
}
%md,在m为正整数时,表示输出的数字占m个单位单位宽度,右对齐,默认用空格来补。
%02d,表示宽度为2,不足的用0来补
实验2-3-1 求1到100的和
本题要求编写程序,计算表达式 1 + 2 + 3 + … + 100 的值。
输入格式:
本题无输入。
输出格式:
按照以下格式输出:
sum = 累加和
#include
int main(){
int sum=0;
for(int i=1;i<=100;i++){
sum+=i;
}
printf("sum = %d",sum);
}
实验2-3-2 求N分之一序列前N项和
本题要求编写程序,计算序列 1 + 1/2 + 1/3 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。
输入样例:
6
输出样例:
sum = 2.450000
#include
int main(){
int n;
double sum=0;
scanf("%d",&n);
for(int i=1;i<=n;i++){
sum+=1.0/i;
}
printf("sum = %.6f",sum);
}
实验2-3-3 求奇数分之一序列前N项和
本题要求编写程序,计算序列 1 + 1/3 + 1/5 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。
输入样例:
23
输出样例:
sum = 2.549541
#include
int main(){
int n;
double sum=0;
scanf("%d",&n);
for(int i=1;i<=(2*n-1);i=i+2){
sum+=1.0/i;
}
printf("sum = %.6f",sum);
}
实验2-3-4 求简单交错序列前N项和
本题要求编写程序,计算序列 1 - 1/4 + 1/7 - 1/10 + … 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后三位。题目保证计算结果不超过双精度范围。
输入样例:
10
输出样例:
sum = 0.819
#include
int main(){
int n;
double sum=0;
scanf("%d",&n);
for(int i=1;i<=(3*n-2);i=i+3){
if(i%2!=0){
sum+=1.0/i;
}else{
sum-=1.0/i;
}
}
printf("sum = %.3f",sum);
}
实验2-3-5 输出华氏-摄氏温度转换表
输入2个正整数lower和upper(lower≤upper≤100),请输出一张取值范围为[lower,upper]、且每次增加2华氏度的华氏-摄氏温度转换表。
温度转换的计算公式:C=5×(F−32)/9,其中:C表示摄氏温度,F表示华氏温度。
输入格式:
在一行中输入2个整数,分别表示lower和upper的值,中间用空格分开。
输出格式:
第一行输出:“fahr celsius”
接着每行输出一个华氏温度fahr(整型)与一个摄氏温度celsius(占据6个字符宽度,靠右对齐,保留1位小数)。
若输入的范围不合法,则输出"Invalid."。
输入样例1:
32 35
输出样例1:
fahr celsius
32 0.0
34 1.1
输入样例2:
40 30
输出样例2:
Invalid.
#include
int main(){
int lower,upper;
double c;
scanf("%d %d",&lower,&upper);
if(lower>upper||upper>100){
printf("Invalid.\n");
}else{
printf("fahr celsius\n");
for(int f=lower;f<=upper;f=f+2){
c=5*(f-32)/9.0;
printf("%d%6.1f\n",f,c);
}
}
}
实验2-3-6 求交错序列前N项和
本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+… 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中输出部分和的值,结果保留三位小数。
输入样例:
5
输出样例:
0.917
#include
int main(){
int n;
double sum=0;
scanf("%d",&n);
for(int i=1;i<=n;i++){
if(i%2!=0){
sum+=1.0*i/(2*i-1);
}else{
sum-=1.0*i/(2*i-1);
}
}
printf("%.3f",sum);
}
实验2-3-7 求平方与倒数序列的部分和
本题要求对两个正整数m和n(m≤n)编写程序,计算序列和m2+1/m+(m+1)2+1/(m+1)+⋯+n2+1/n。
输入格式:
输入在一行中给出两个正整数m和n(m≤n),其间以空格分开。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。
输入样例:
5 10
输出样例:
sum = 355.845635
#include
int main(){
int m,n;
double sum=0;
scanf("%d %d",&m,&n);
for(int i=m;i<=n;i++){
sum+=i*i+1.0/i;
}
printf("sum = %.6f",sum);
}
实验2-4-2 生成3的乘方表
输入一个非负整数n,生成一张3的乘方表,输出30~3n的值。可调用幂函数计算3的乘方。
输入格式:
输入在一行中给出一个非负整数n。
输出格式:
按照幂的递增顺序输出n+1行,每行格式为“pow(3,i) = 3的i次幂的值”。题目保证输出数据不超过长整型整数的范围。
输入样例:
3
输出样例:
pow(3,0) = 1
pow(3,1) = 3
pow(3,2) = 9
pow(3,3) = 27
#include
#include
int main(){
int n;
scanf("%d",&n);
for(int i=0;i<=n;i++){
int result=pow(3,i);
printf("pow(3,%d) = %d\n",i,result);
}
}
实验2-4-3 求平方根序列前N项和
本题要求编写程序,计算平方根序列√1+√2+√3+⋯的前N项之和。可包含头文件math.h,并调用sqrt函数求平方根。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后两位。题目保证计算结果不超过双精度范围。
输入样例:
10
输出样例:
sum = 22.47
#include
#include
int main(){
int n;
double sum=0;
scanf("%d",&n);
for(int i=1;i<=n;i++){
sum+=sqrt(i);
}
printf("sum = %.2f",sum);
}
实验2-4-4 求阶乘序列前N项和
本题要求编写程序,计算序列 1!+2!+3!+⋯ 的前N项之和。
输入格式:
输入在一行中给出一个不超过12的正整数N。
输出格式:
在一行中输出整数结果。
输入样例:
5
输出样例:
153
#include
int main(){
int n;
int p=1,sum=0;
scanf("%d",&n);
for(int i=1;i<=n;i++){
p=p*i;
sum+=p;
}
printf("%d",sum);
}
实验2-4-6 求幂之和
本题要求编写程序,计算sum=21+22+23+⋯+2n。可以调用pow函数求幂。
输入格式:
输入在一行中给出正整数n(≤10)。
输出格式:
按照格式“result = 计算结果”输出。
输入样例:
5
输出样例:
result = 62
#include
#include
int main(){
int n,sum=0;
scanf("%d",&n);
for(int i=1;i<=n;i++){
sum+=pow(2,i);
}
printf("result = %d",sum);
}
实验2-4-7 求组合数
本题要求编写程序,根据公式Cnm=m!(n−m)!n!算出从n个不同元素中取出m个元素(m≤n)的组合数。
建议定义和调用函数fact(n)计算n!,其中n的类型是int,函数类型是double。
输入格式:
输入在一行中给出两个正整数m和n(m≤n),以空格分隔。
输出格式:
按照格式“result = 组合数计算结果”输出。题目保证结果在double类型范围内。
输入样例:
2 7
输出样例:
result = 21
#include
double fact(int n){
if(n==1||n==0) return 1;
return n*fact(n-1);
}
int main(){
int m,n;
double result;
scanf("%d %d",&m,&n);
result=fact(n)/(fact(m)*fact(n-m));
printf("result = %d",(int)result);
}
c语言类型强制转换:(类型)变量名