C语言问题,求详细解题过程
fun(float*p1,intn,float*p2,intm,float*s){inti;*s=0.0;for(i=0;i<n;i++)*s+=*p1++;for(i=...
fun(float*p1,int n,float*p2,int m,float*s) {int i; *s=0.0; for(i=0;i<n;i++)*s+=*p1++; for(i=0;i<m;i++)*s+=*p2++; } main() { float a[]={1.1,2.2},b[]={1.0,2.0,3.0),*s=a; fun(a,2,b,3,s); printf("%f\n",*s); } 上面程序的输出结果是______。
展开
2个回答
展开全部
/*** fun(float*p1,int n,float*p2,int m,float*s) 前面一定要加 void *****/
void fun(float*p1,int n,float*p2,int m,float*s)
{int i;
*s=0.0;
for(i=0;i<n;i++)*s+=*p1++;
for(i=0;i<m;i++)*s+=*p2++;
}
/*** 修改一下,避免特殊情况 */
void fun1(float*p1,int n,float*p2,int m,float*s)
{int i; float t=0.0; /***非常安全, t是局部变量,不会修改任何东西!*****/
for(i=0;i<n;i++)t+=*p1++;
for(i=0;i<m;i++)t+=*p2++;
*s=t; /*** 这下修改就安全了,所有计算结束了,不会变化了 ***/
}
/***
修改后输出9.3;
*****/
/*** main() 一定要写 int,有别偷懒 *****/
int main()
{
float a[]={1.1,2.2},b[]={1.0,2.0,3.0),*s=a;
fun(a,2,b,3,s);
/************* 下面模拟调用过程
fun(a,2,b,3,s);
参数传递过程,借用C++的 :: 运算符
fun::p1 = main::a;
fun::n = 2;
fun::p2 = main::b;
fun::m = 3;
fun::s = main::s=main::a;
函数调用过程:
void fun(float*p1,int n,float*p2,int m,float*s)
{int i;
<<<<<<<<<<<p1 = main::a;p2 = main::b;s = main::s=main::a;
*s=0.0;<===>main::a[0]=0.0;特殊情况(1.1变成0.0了),也可以避免
for(i=0;i<n;i++)*s+=*p1++;<=>*s+=*p1;p1++;<=>main::a[0]+=main::a[i];
for(i=0;i<m;i++)*s+=*p2++;<=>*s+=*p2;p2++;<=>main::a[0]+=main::b[i];
=====>调用结束 *s=main::a[0]=Σa +Σb=0.0+2.2+1.0+2.0+3.0= 8.2;
}
**************/
printf("%f\n",*s); /*** 输出8.2; s=a; *s=a[0] =Σa +Σb=8.2; *****/
return 0;/*** 一定要有别偷懒 *****/
}
void fun(float*p1,int n,float*p2,int m,float*s)
{int i;
*s=0.0;
for(i=0;i<n;i++)*s+=*p1++;
for(i=0;i<m;i++)*s+=*p2++;
}
/*** 修改一下,避免特殊情况 */
void fun1(float*p1,int n,float*p2,int m,float*s)
{int i; float t=0.0; /***非常安全, t是局部变量,不会修改任何东西!*****/
for(i=0;i<n;i++)t+=*p1++;
for(i=0;i<m;i++)t+=*p2++;
*s=t; /*** 这下修改就安全了,所有计算结束了,不会变化了 ***/
}
/***
修改后输出9.3;
*****/
/*** main() 一定要写 int,有别偷懒 *****/
int main()
{
float a[]={1.1,2.2},b[]={1.0,2.0,3.0),*s=a;
fun(a,2,b,3,s);
/************* 下面模拟调用过程
fun(a,2,b,3,s);
参数传递过程,借用C++的 :: 运算符
fun::p1 = main::a;
fun::n = 2;
fun::p2 = main::b;
fun::m = 3;
fun::s = main::s=main::a;
函数调用过程:
void fun(float*p1,int n,float*p2,int m,float*s)
{int i;
<<<<<<<<<<<p1 = main::a;p2 = main::b;s = main::s=main::a;
*s=0.0;<===>main::a[0]=0.0;特殊情况(1.1变成0.0了),也可以避免
for(i=0;i<n;i++)*s+=*p1++;<=>*s+=*p1;p1++;<=>main::a[0]+=main::a[i];
for(i=0;i<m;i++)*s+=*p2++;<=>*s+=*p2;p2++;<=>main::a[0]+=main::b[i];
=====>调用结束 *s=main::a[0]=Σa +Σb=0.0+2.2+1.0+2.0+3.0= 8.2;
}
**************/
printf("%f\n",*s); /*** 输出8.2; s=a; *s=a[0] =Σa +Σb=8.2; *****/
return 0;/*** 一定要有别偷懒 *****/
}
展开全部
结果是 8.200000
解释我以注释的形式写了:
#include<stdio.h>
#include<stdlib.h>
void fun(float*p1,int n,float*p2,int m,float*s)
{
int i;
*s=0.0; //因为main函数中有s=a,所以*s=0.0也就是*a=0.0,也就是说a[0]=0.0,所以这一句之后a[0]就变成了0.0
for(i=0;i<n;i++)
*s+=*p1++;//这一句比较晦涩,我改写一下:(*s) = (*s) + (*p1);p1++;这样就好理解多了吧
//之所以是这么该写,从优先级来看:*>+=>++,++运算符是先引用,再加一
//又因为s=a,p1=a,
//所以这个循环的意思是把数组a的元素累加起来存到*s,也就是a[0],注意:a[0]已经在前面赋值为0.0了
//所以累加之后a[0]=2.2
for(i=0;i<m;i++)
*s+=*p2++;//这一句同理,改写一下:(*s) = (*s) + (*p2);p2++;
//理解了前一个循环,这个循环就好理解了,就是把b数组的元素累加起来再加上循环之前的*s,存到*s
//不难算出:2.2+1.0+2.0+3.0=8.2,也就是说*s=8.2
}
int main()
{
float a[]={1.1,2.2},b[]={1.0,2.0,3.0},*s=a;
fun(a,2,b,3,s);
printf("%f\n",*s);//这里是浮点型输出,没有指定多少位,所以默认是6位小数,也就是8.200000
}
解释我以注释的形式写了:
#include<stdio.h>
#include<stdlib.h>
void fun(float*p1,int n,float*p2,int m,float*s)
{
int i;
*s=0.0; //因为main函数中有s=a,所以*s=0.0也就是*a=0.0,也就是说a[0]=0.0,所以这一句之后a[0]就变成了0.0
for(i=0;i<n;i++)
*s+=*p1++;//这一句比较晦涩,我改写一下:(*s) = (*s) + (*p1);p1++;这样就好理解多了吧
//之所以是这么该写,从优先级来看:*>+=>++,++运算符是先引用,再加一
//又因为s=a,p1=a,
//所以这个循环的意思是把数组a的元素累加起来存到*s,也就是a[0],注意:a[0]已经在前面赋值为0.0了
//所以累加之后a[0]=2.2
for(i=0;i<m;i++)
*s+=*p2++;//这一句同理,改写一下:(*s) = (*s) + (*p2);p2++;
//理解了前一个循环,这个循环就好理解了,就是把b数组的元素累加起来再加上循环之前的*s,存到*s
//不难算出:2.2+1.0+2.0+3.0=8.2,也就是说*s=8.2
}
int main()
{
float a[]={1.1,2.2},b[]={1.0,2.0,3.0},*s=a;
fun(a,2,b,3,s);
printf("%f\n",*s);//这里是浮点型输出,没有指定多少位,所以默认是6位小数,也就是8.200000
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询