DAY 8

作业一、定义有参函数实现,主调函数中输入两个数据,通过函数调用,交换该两个变量的值,主调函数输出交换后的结果。

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

	void f(int *i, int *j);
	void f(int *i,int *j)
{
	int temp = *i;
	*i=*j;
	*j=temp;

}

int main(int argc, const char *argv[])
{
	int m,n;   //定义两个变量

	printf("请输入两个数值:");
	scanf("%d%d",&m,&n);
	f(&m,&n);
	printf("交换后的数值为%d\t%d\n",m,n);
	return 0;
}

 

作业二:定义函数实现,主调函数中,输入6名学生成绩,调用函数求6名学生的平均值,将平均值返回给主函数并输出。要求:使用主调函数中传递数组,被调函数使用指针接收

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

	double average(int *p,int n)
{
	double sum=0,avg=0;
	
	for(int i=0;i<n;i++)
	{
		sum+=p[i];
		avg=sum/n;
	}
	return avg;
}


int main(int argc, const char *argv[])
{
	int arr[6];

	for(int i=0;i<6;i++)
	{
	
	printf("请输入%d名学生的成绩:",i+1);
	scanf("%d",&arr[i]);

	if(arr[i]<0||arr[i]>100)
		{
		printf("输入有误,请重新输入");
			i--;
		}
	}
	double avg=average(arr,6);
	printf("学生成绩的平均值为:%.2lf\n",avg);

	
	return 0;
}

 作业三、定义一个长度为5的一维数组,在主函数内实现输入元素功能,调用函数实现该数组的降序输出,要求形参与实参使用指针完成。

ubuntu@ubuntu:day8$ cat 03test.c 
#include<string.h>
#include<stdio.h>
#include<stdlib.h>

//冒泡排序降序
	void pro(int *p,int n)
{

	for(int i=1;i<n;i++)   //外侧控制趟数
	{
		for(int j=0;j<n-i;j++)  //控制比较次数
		{
			if (*(p+j)<*(p+j+1))
			{
				//交换数值
				int temp=*(p+j);
				*(p+j)=*(p+j+1);
				*(p+j+1)=temp;
			}
		}
	}
	printf("从大到小排序为:");
	for(int i=0;i<n;i++)
	{
		printf("%d\t",p[i]);
	}
	printf("\n");
}


int main(int argc, const char *argv[])
{
	int arr[5];
	for(int i=0;i<5;i++)
	{
	printf("请输入%d个元素",i+1);
	scanf("%d",&arr[i]);
	}

	pro(arr,5);
	
	return 0;
}

 作业四、定义一个长度为5的一维数组,在主函数内实现输入元素功能,调用函数实现该数组的逆置,要求形参与实参使用指针完成。

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


	void rever(int *p,int n)
{
	int i;
	printf("逆置后的数组为:");
	for(i=n-1;i>=0;i--)   	
	{
		printf("%d\t",p[i]);
	}
	printf("\n");
}


int main(int argc, const char *argv[])
{
	int arr[5];
	for(int i=0;i<5;i++)
	{
	printf("请输入%d个元素",i+1);
	scanf("%d",&arr[i]);
	}

	rever(arr,5);
	
	return 0;
}

 

作业五、一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过七个村子后还剩两只鸭子,问他出发时共赶多少只鸭子?使用递归函数求鸭子总数。

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

	int fun (int n)
{
	if(n==0)
	{
		return 0;
	}else
	{
	return 2*fun(n-1)+1;
	}
}
int main(int argc, const char *argv[])
{
	
	printf("出发时赶了%d只鸭子",fun(7));

	
	return 0;
}

 

作业六、小明想要编写一个递归函数,接受一个非负整数,并输出该数的所有位,请你帮帮他吧。

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

void zhengshu(int num)
{
	if(num==0)
	{
		return;
	}else
	{
	 zhengshu(num/10);
	 printf("%d ",num%10);
	}
}
int main(int argc, const char *argv[])
{

	int n;
	printf("请输入一个非负整数:");
	scanf("%d",&n);

	zhengshu(n);
	
	return 0;

}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值