1.生成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
代码1:
#include<stdio.h>
#include<math.h>
int main()
{
int i,n;
double power;
scanf("%d",&n);
for(i=0;i<=n&&n>=0;i++)
{
power=pow(3,i);
printf("pow(3,%d) = %.0f\n",i,power);
}
return 0;
}
代码2:
#include<stdio.h>
#include <math.h>
int main()
{
int i,n;
scanf("%d",&n);
for(i=0;i<=n;i++)
printf("pow(3,%d) = %ld\n",i,(long)pow(3,i));
return 0;
}
2.求组合数
题目:本题要求编写程序,根据公式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
代码1:
#include<stdio.h>
double fact(int a)
{
double result=1;
int i;
for(i=1;i<=a;i++)
{
result=result*i;
}
return result;
}
int main()
{
int m,n;
double b,c,d,e;
scanf("%d%d",&m,&n);
b=fact(n);
c=fact(m);
d=fact(n-m);
e=b/(c*d);
printf("result = %.0f",e);
return 0;
}
代码2:
#include<stdio.h>
int main()
{
int m,n,i;
double fact1=1,fact2=1,fact3=1;
scanf("%d%d",&m,&n);
for(i=1;i<=n;i++)
fact1=fact1*i;
for(i=1;i<=m;i++)
fact2=fact2*i;
for(i=1;i<=n-m;i++)
fact3=fact3*i;
printf("result = %.0f\n",fact1/fact2/fact3);
return 0;
}