作业1:定义有参函数实现,主调函数中输入两个数据,通过函数调用,交换该两个变量的值,主调函数输出交换后的结果;
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
int exchange (int *p,int *q)
{
int temp=0;
temp=*p;*p=*q;*q=temp; //通过地址传递将值给改变;
}
int main(int argc, const char *argv[])
{
int m=0;
int n=0;
printf("请输入两个数据的值:");
scanf("%d%d",&m,&n);
int *p=&m; ///定义一个指针得到输入数据的地址;
int *q=&n;
exchange(p,q);
printf("两个数据交换后输出:%d\t%d\n",m,n);
return 0;
}
作业2:定义函数实现,主调函数中,输入6名学生成绩,调用函数求6名学生成绩的平均值,将平均值返回给主函数并输出。
要求:使用主调函数中传递数组,被调函数使用指针接收
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
double pjz(int *p,int n)
{
int sum=0;
for(int i=0;i<n;i++)
{
sum = sum+p[i];
}
double evg = (double)sum/n;
return evg;
}
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]);
}
double ret =pjz(arr,6);
printf("该6名学生成绩的平均值为:%.2lf\n",ret);
return 0;
}
作业3:定义一个长度为5的一维数组,在主函数内实现输入元素功能,调用函数实现该数组的降序输出,要求形参与实参皆使用指针完成。
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
void jiangxu(int *q,int n)
{
for(int i=1;i<n;i++)
{
for(int j=0;j<n-i;j++)
{
if(q[j]<q[j+1])
{
int temp=0;
temp=q[j+1];
q[j+1]=q[j];
q[j]=temp;
}
}
}
printf("降序排列后的5个元素的值为:");
for(int i=0;i<n;i++)
{
printf("%d\t",q[i]);
}
printf("\n");
}
int main(int argc, const char *argv[])
{
int i=0;
int arr[5];
int *p=arr;
for( i=0;i<5;i++)
{
printf("请输入第%d个元素:",i+1);
scanf("%d",&p[i]);
}
jiangxu(p,5);
return 0;
}
作业4:定义一个长度为5的一维数组,在主函数内实现输入元素功能,调用函数实现该数组的逆置,要求形参与实参皆使用指针完成;
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
void nizhi(int *q,int n)
{
for(int i=0;i<n/2;i++)
{
int temp=0;
temp=q[i];
q[i]=q[n-1-i];
q[n-1-i]=temp;
}
printf("逆置排列后的5个元素的值为:");
for(int i=0;i<n;i++)
{
printf("%d\t",q[i]);
}
printf("\n");
}
int main(int argc, const char *argv[])
{
int i=0;
int arr[5] ;
int *p=arr;
for( i=0;i<5;i++)
{
printf("请输入第%d个元素:",i+1);
scanf("%d",&p[i]);
}
nizhi(p,5);
return 0;
}
作业5:一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过了七个村子后还剩两只鸭子,问他出发时共赶了多少只鸭子?使用递归函数求出鸭子总数。
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
int dunk(int n)
{
if(n==7)
{
return 2;
}else
{
return 2*(dunk(n+1)+1);
}
}
int main(int argc, const char *argv[])
{
int n=0;
int num=dunk(n);
printf("出发时总共赶了%d只鸭子\n",num);
return 0;
}
作业6:小明想要编写一个递归函数,接收一个非负整数,输出该数的所有位,请你帮帮他吧。
代码:
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
int number(int n)
{
if(n/10==0) //判断是不是个位数,如果是直接输出;
{
printf("%d\t",n);
}
else
{
printf("%d\t",n%10); //得到你所输入整数的个位数;
return number(n/10); //去掉个位数得到一个新的数输入;
}
printf("\n");
}
int main(int argc, const char *argv[])
{
int m=0;
printf("请输入一个非负整数:");
scanf("%d",&m);
for(int i=0;i>0;i++)
{
if(m<0)
{
printf("您输入的数据有误!!");
i--;
}else
{
break;
}
}
number(m);
return 0;
}