可变参数编程
可变参数编程
1.第一个形参不能省,提供找…的位置线索
C语言:实际参数入栈是从右向左
1.参数入栈的考题
int arr[]={1,2,3,4,5};
int i=2;
printf("%d,%d\n",arr[i++],arr[i+1]);// 4 3 i++的副作用,先运算后自加
//从右向左入栈
2.可变参数编程实例
int Avg(int n,...)
{
return 0;
}
#include<stdio.h>
#include<assert.h>
#include<stdarg.h> //可变参数编程
int Avg(int n, ...)
{
int sum = 0;
va_list list; //定义一个宏
va_start(list, n); //将list定位到...的开头
for (int i = 0; i < n; ++i) //从...中取出n个数字
{
sum += va_arg(list, int); //从...中取数据
}
va_end(list); //关闭指针
return sum/n;
}
int main()
{
printf("%d\n", Avg(1, 10));
printf("%d\n", Avg(2, 10,20));
printf("%d\n", Avg(3, 10,20,30));
printf("%d\n", Avg(4, 10,20,30,40));
printf("%d\n", Avg(5, 10,20,30,40,50));
return 0;
}