![](https://img-blog.csdnimg.cn/img_convert/972cda890382c992b616e82c815d96ea.jpeg)
第一题
#include<stdio.h>
double min(double a,double b)
{
return (a<b)?a:b;
}
int main()
{
double a,b;
scanf("%lf %lf",&a,&b);
printf("%f\n",min(a,b));
return 0;
}
第二题
#include<stdio.h>
void chline(char,int,int);
int main()
{
char ch;
int i,j;
ch=getchar();//要放在输入i和j前面,否则在输入j之后不能输入空格,要直接输入待打印的字符
scanf("%d %d",&i,&j);
chline(ch,i,j);
return 0;
}
void chline(char ch,int i,int j)
{
for(int a=0;a<i;a++){
for(int b=0;b<j;b++){
putchar(ch);
}
putchar('\n');
}
}
第三题和第二题类似
第四题
#include<stdio.h>
double average(double,double);
int main()
{
double a,b;
scanf("%lf %lf",&a,&b);
printf("%f和%f的调和平均数是%f\n",a,b,average(a,b));
return 0;
}
double average(double a,double b)
{
double c;
c=(1/a+1/b)/2;
return 1/c;//或者直接return 2/(1/a+1/b);
}
第五题
这里要改变主函数中的变量,所以要用到指针
#include<stdio.h>
void larger(double *,double *);
int main()
{
double a,b;
scanf("%lf %lf",&a,&b);
larger(&a,&b);
printf("%f %f",a,b);
return 0;
}
void larger(double *a,double *b)
{
if(*a>*b){
*b=*a;
}else{
*a=*b;
}
//*a>*b?(*b=*a):(*a=*b);
}
第六题
#include<stdio.h>
void paixu(double *,double *,double *);
int main()
{
double a,b,c;
scanf("%lf %lf %lf",&a,&b,&c);
paixu(&a,&b,&c);
printf("%f %f %f\n",a,b,c);
return 0;
}
void paixu(double *a,double *b,double *c)
{
double t;
if(*a>*b){
t=*a;
*a=*b;
*b=t;
}
if(*b>*c){
t=*b;
*b=*c;
*c=t;
}
if(*a>*c){
t=*a;
*a=*c;
*c=t;
}
}
第七题目前没有写好
第八题
#include<stdio.h>
#include<math.h>
double power(double,int);
int main()
{
double x;
int n;
while(scanf("%lf %d",&x,&n)==2){
printf("%lf",power(x,n));
}
return 0;
}
double power(double x,int n)
{
double ret=1;
if(x==0&&n!=0){
ret=0;
}
if(n==0){
ret=1;
}
if(n>0){
for(int i=1;i<=n;i++){
ret*=x;
}
}
else{
for(int j=1;j<=abs(n);j++){
ret*=x;
}
ret=1/ret;
}
return ret;
}
第九题写的运行不成功,改改再写
第十题
注意下面这种方法只能解决整数之间的转换,用的是递归的方法,比较简单
#include<stdio.h>
void to_binary(int n,int a);
int main()
{
int n,a;
printf("请输入两个整数,第一个是十进制数,第二个为转化的进制(2~10),输入q程序结束:\n");
while(scanf("%d %d",&n,&a)==2){
to_binary(n,a);
printf("请输入两个整数,第一个是十进制数,第二个为转化的进制(2~10),输入q程序结束:\n");
}
return 0;
}
void to_binary(int n,int a)
{
int r;
r=n%a;
if(n>=a){
to_binary(n/a,a);
}
printf("%d",r);
}
第十一题
用递归求某一项
#include<stdio.h>
int fibonacci(int n);
int main()
{
int n;
printf("按q停止程序,否则继续.\n");
while(scanf("%d",&n)==1){
printf("斐波那契数列的第%d项是%lu\n",n,fibonacci(n));
}
return 0;
}
int fibonacci(int n)
{
unsigned long ret;
if(n==1||n==2){
ret=1;
}else{
ret=fibonacci(n-1)+fibonacci(n-2);
}
return ret;
}
用循环打印出前n项
#include<stdio.h>
void fibonacci(int n);
int main()
{
int n;
while(scanf("%d",&n)==1){
fibonacci(n);
}
}
void fibonacci(int n)
{
unsigned long f1,f2,temp;
f1=1;
f2=1;
for(int i=0;i<n;i++){
printf("%lu ",f1);
temp=f1+f2;
f1=f2;
f2=temp;
}
printf("\n");
}