| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 677 人关注过本帖
标题:求助数组赋值的问题
只看楼主 加入收藏
magiclyy
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2013-10-21
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:10 
求助数组赋值的问题
我是新手,刚开始自学C。
题目是:《C Primer Plus 》第六章的编程习题。
6.13编写一个程序,创建两个8元素的double数组,使用一个循环来让用户键入第一个数组的8个元素的值。程序把第二个数组的元素设置为第一个数组元素的累积和。例如,第二个数组的第4个元素应该等于第一个数组的前4个元素的和,第二个数组的第5个元素应该等于第一个数组的前5个元素的和(使用嵌套循环可以做到这一点。不过利用第二个数组的第5个元素等于第二个数组的第4个元素加上第一个数组的第5个元素这一事实,可以避免嵌套而只使用单个循环来完成这个任务)。最后,使用一个循环来显示两个数组中的内容,第一个数组在一行中显示,而第二数组中的第个元素在第一个数组的对应元素之下进行显示。

以下是正确答案:
#include <stdio.h>
#define N 8
int main (void)
{
  double shuzu1[N],shuzu2[N],mid;
  int i;
  shuzu2[0] = 0.0;
  printf("Enter 8 numbers for shuzu1:\n");
  for (i = 0;i<N;i++)  {
    scanf("%lf",&shuzu1[i]);
    }

    mid = 0;
   for (i = 0;i<N;i++) {          就是这里的问题,为什么一定要一个中间值mid,而不能直接赋值:先把shuzu2[0] = 0 ;  然后 shuzu2[i] += shuzu1[i];
     mid += shuzu1[i];
     shuzu2[i] = mid;
     }


   for (i = 0;i<N;i++) {
     printf("%.6lf ",shuzu1[i]);
     }

    printf("\n");

    for (i = 0;i<N;i++) {
     printf("%.6lf ",shuzu2[i]);
     }

  getch();
  return 0;
}
搜索更多相关主题的帖子: double 用户 元素 
2013-10-23 21:24
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
没看你的题目,只是看你的代码和提问。


 for (i = 0;i<N;i++) {
    mid += shuzu1[i];
    shuzu2[i] = mid;
 }
等价于
shuzu2[i] = shuzu1[0] + shuzu1[1]……shuzu1[i];



shuzu2[0] = 0 ;  然后 shuzu2[i] += shuzu1[i];
等价于shuzu2[i] = shuzu2[i] + shuzu1[i];

你认为是一样的吗?

 

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-23 22:31
magiclyy
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2013-10-21
收藏
得分:0 
回复 2楼 yuccn
我是这个意思:
shuzu2[0] = 0;
for (i = 0;i<N;i++) {
    shuzu2[i] += shuzu1[i];
    }


当i = 0 时,shuzu2[0] =0 + shuzu1[0] = shuzu1[0] ,后者把值赋予了前者,后面shuzu2[1] = shuzhu2[0] + shuzu1[1] = shuzu1[0] +shuzu1[1] 。以此类推:
shuzu2[i] = shuzu1[0] + shuzu1[1] + ...。。。+ shuzu[i]。但是为什么这么做就会错呢?非要加一个中间值做桥梁?
2013-10-23 23:40
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
for (i = 0;i<N;i++) {
    shuzu2[i] += shuzu1[i];
    }

等价于
shuzu2[0] += shuzu1[0];
shuzu2[1] += shuzu1[1];
shuzu2[2] += shuzu1[2];
::::::
shuzu2[i] += shuzu1[i];

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-24 08:08
a592963144
Rank: 2
等 级:论坛游民
帖 子:41
专家分:95
注 册:2013-9-27
收藏
得分:0 
LZ 的误区 在这里
 按你说的:i=0时shuzu2[0]=0+shuzu1[0]=shuzu1[0]
           i=1时shuzu2[1]=shuzhu2[0]+shuzu1[1]=shuzu1[0]+shuzu1[1](你觉得这里符合表达式 shuzu2[i] += shuzu1[i];吗???)
  如果按你说的改掉mid  i=a时  就应该是这样的 shuzu2[1]=shuzhu2[1]+shuzu1[1]
                                                                         |
                                                                     这个值怎么算???
2013-10-24 09:10
a592963144
Rank: 2
等 级:论坛游民
帖 子:41
专家分:95
注 册:2013-9-27
收藏
得分:0 
这个值怎么算? 指的是shuzhu2[1](不小心指错了)
2013-10-24 09:12
在这里爬起
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:43
专家分:113
注 册:2013-8-9
收藏
得分:0 
回复 3楼 magiclyy
后面shuzu2[1] = shuzhu2[0] + shuzu1[1] = shuzu1[0] +shuzu1[1] 。这个与你的shuzu2[i]+=shuzu[i],有出入
2013-10-24 09:41
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
mid = 0;
for (i = 0;i<N;i++) {
    mid += shuzu1[i];
    shuzu2[i] = mid;
}

等价于
for (i = 0;i<N;i++) {
    shuzu2[i] = 0;
    for (int j = 0; i <= i; j++) {
        shuzu2[i] += shuzu1[j];  // shuzu2[i] = shuzu2[i] + shuzu1[j]
    }
}

你看看这个和你的是否一样,自己在细细想想

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-24 09:43
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
mid 只不是是一个中间变量,把之前计算过的sum(shuzu1[0] - shuzu1[i])保存起来,没有每次从头计算一遍而已。

[ 本帖最后由 yuccn 于 2013-10-24 09:46 编辑 ]

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-24 09:45
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:20 
按你的说法;
for (i = 0;i<N;i++) {
    shuzu2[i] = 0;
    for (int j = 0; i <= i; j++) {
        shuzu2[i] += shuzu1[j];  // shuzu2[i] = shuzu2[i] + shuzu1[j]
    }
}



shuzu2[0] = 0
for (i = 0;i<N;i++) {          就是这里的问题,为什么一定要一个中间值mid,而不能直接赋值:先把shuzu2[0] = 0 ;  然后 shuzu2[i] += shuzu1[i];
    shuzu2[i] += shuzu1[i];
}

是一样的? 差天和地把

原题目的是
shuzu2[i] = sum (shuzu1[0] 到 shuzu1[i])

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-24 09:50
快速回复:求助数组赋值的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017169 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved