这题怎么读,for循环给数组赋值怎么套进for

c语言中数组的题目(急)请问是怎么算的,有两个for,怎么循环啊_百度知道
c语言中数组的题目(急)请问是怎么算的,有两个for,怎么循环啊
main(){int a[3][3]={{1,2},{3,4},{5,6}},i,j,s=0;for(i=1;i&3;i++)for(j=0;j&=i;j++)s+=a[i][j];printf(&%d\n&,s);}
输出结果是18,不知道是怎么算的??
我有更好的答案
第0列 第1列
0因为数组a定义为3*3,所以第2列自动补0.for(i=1;i&3;i++)for(j=0;j&=i;j++)s+=a[i][j];i可取1,2当i是1时,j可以取0,1当i是2时,j可以取0,1,2所以s是这5个位置的数字的总和:s=a[1][0] + a[1][1] + a[2][0] + a[2][1] + a[2][2] = 3 + 4 + 5 + 6 + 0 =18
采纳率:29%
i的值为1 2,j的值为从0开始到i的值因此当i=1时,j取0 1,于是s=s+a[1][0]+a[1][1]=3+4=7当i=2时,j取0,1,2三个值 ,于是 s=7+a[2][0]+a[2][1]+a[2][2]=7+5+6+0=18.注意到数组a中,j=2时的所有值都是0就行了。
由题知:a[][]={1,2,0
}当i=1时;s+=3+4=7;当i=2时:s+=5+6=0,s=18;即最后的结果是18
很简单,i只运行二次1、 i为1时,j的值为0,1,分别为a[1][0],a[1][1]2、 i为2时,j的值为0,1,2
分别为a[2][0],a[2][1],a[2][2]所以 s=a[1][0]+a[1][1]+a[2][0]+a[2][1]+a[2][2]
= 3+4+5+6+0
其他1条回答
为您推荐:
其他类似问题
您可能关注的内容
c语言的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。请问哪位大神知道第四题和第五题用for加数组怎么做,(不求答案,求讲解,)_百度知道
请问哪位大神知道第四题和第五题用for加数组怎么做,(不求答案,求讲解,)
我有更好的答案
4.求字符串长度的程序:#include&stdio.h&#include&string.h&void main(){
printf(&输入的字符串:&);
while(a[i] != '\0')
printf(&你输入的字符串的长度为%d\n&,i);}运行结果输入的字符串:abcdefgh你输入的字符串的长度为85.将大写字母循环右移5位的程序:#include&stdio.h&#include&string.h&void main(){
ch='A',i= 0;
while(i&26)
if(ch+5&'Z')
printf(&%c&,ch-26);
printf(&%c&,ch+5);
printf(&\n&);
fflush(stdout);}
有没有用for循环做的第四题大神
4.求字符串长度的程序:#include&stdio.h&#include&string.h&void main(){char a[100];a[0]=0;printf(&输入的字符串:&);gets(a);for(i=0; a[i] != '\0'; i++) ;printf(&你输入的字符串的长度为%d\n&,i);}运行结果输入的字符串:abcdefgh你输入的字符串的长度为85.将大写字母循环右移5位的程序:#include&stdio.h&#include&string.h&void main(){int ch='A',i;for(i=0; i&26; i++){if(ch+5&'Z')
printf(&%c&,ch-26);else
printf(&%c&,ch+5);
ch++;}printf(&\n&); fflush(stdout);}
采纳率:91%
来自团队:
为您推荐:
其他类似问题
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。第4章数组练习题_百度文库
赠送免券下载特权
10W篇文档免费专享
部分付费文档8折起
每天抽奖多种福利
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
第4章数组练习题
阅读已结束,下载本文需要
想免费下载本文?
定制HR最喜欢的简历
下载文档到电脑,同时保存到云知识,更方便管理
加入VIP
还剩4页未读,
定制HR最喜欢的简历
你可能喜欢js 数组的for循环到底应该怎么写?
转载 &更新时间:日 23:26:05 & 作者:
说实话,我是个比较喜欢怀疑权威的人,但是在有些权威的问题一直在我面前闪,闪啊闪,我就开始不怀疑他们了,因为有10000个人说这个东西是对的,我就会觉得它的确是对的吧。
然后来看看今天我开始怀疑哪个权威哦家伙了。。。 自从开始学编程,自从接触到数组这个东西,我就一直在不同的地点和不同的时间不断看到有人提醒:在用for遍历数组的时候一定要用 for(var i=0,n=arr2.i&n;i++)的方式哦,而不要用for(var i=0;i&arr.i++)的方式哦,因为用脑子想想也知道,第二种方法的第二部分会一直去计算数组的length,所以自然效率比较低。 哦?我们这里不说其他程序语言,而只讨论js,因为不同的语言,实现可能不同,其他语言是什么情况还要靠大家去探索喽。 其实上面说到的所谓的“动脑子想想就知道”也许只是因为大家只是用脑子想了想,而不是仔细想了想或者亲自去试了试。所以现在我们仔细想想,第一种写法真的会比第二种写法快么?arr.length会耗费很多cpu么?不会啊,为什么要耗费cpu呢?arr.length并不是调用了一个方法,而只是读取了一下数组的length属性啊,你认为读取原生属性和读取定义的变量,哪个会快呢? 我认为读取length会更快,所以我写了个测试来测试自己的想法: 我用了一个我自己的小测试框架,
代码如下: var arr=[],arr2=[],i=0 while(i&100000){ arr.push(i) arr2.push(i) i++ } M.TA.begin("0000"); for(var i=0;i&arr.i++){ arr[i]=arr[i]*arr[i]*arr[i] } M.TA.end("0000","for(var i=0;i&arr.i++)") M.TA.begin("0001"); for(var i=0,n=arr2.i&n;i++){ arr2[i]=arr2[i]*arr2[i]*arr2[i] } M.TA.end("0001"," for(var i=0,n=arr2.i&n;i++)") M.TA.showResult()
当然,这段代码是很变态的,占用了300多兆的内存。 结果如下: chrome firefox (在做过N种性能测试后发现firefox在基础运算上的效率比chrome高很多,只是涉及到渲染的就慢很多了) ie8 (减少了N个数量级之后的记过,上述脚本在ie里无法运行) 总结:? 其实做这个测试不是为了强调for(var i=0;i&arr.i++)的写法快多少,因为测试也是有些许误差的,只是为了说明这种写法并不会慢到哪里去,而且这种写法有一定的灵活性,书写也简单,代码量又少,那我们为什么不用它呢? 如果是第一种写法,在循环的时候数组长度发生变化呢?这种情况就处理不了了吧 其实我还是尊敬权威的,所以写到这里的时候我心里仍然提心吊胆,难道是我哪里搞错了么?如果是,大家就当一笑而过吧,如果不是,那我总算写了篇人模狗样的博文了。。。 转载注明: http://www.html-js.com
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具您还可以使用以下方式登录
当前位置:&>&&>&&>& > 面试题之数组统计
面试题之数组统计
题目:给定数组A,大小为n,数组元素为0到n-1的数字,不过有的数字出现了多次,有的数字没有出现。请给出算法和程序,统计哪些数字没有出现,哪些数字出现了多少次。要求在O(n)的时间复杂度,O(1)的空间复杂度下完成。&解法一:直接用两层遍历,O(n^2)的时间复杂度,O(1)的空间复杂度&#include &stdio.h&
#include &stdlib.h&
int main()
int n, i, j, count = 0;
//n is The length of the Array
while (scanf(&%d&, &n) != EOF)
int *a = malloc(sizeof(int) * n);
for (i = 0; i & i++)
scanf(&%d&, &a[i]);
for (i = 0; i & i++)
count = 0;
for (j = 0; j & j++)
if (i == a[j])
if (count == 0)
printf(&%d does not appear in the array!\n&, i);
printf(&%d appear in the array for %d times\n&, i, count);
&解法二:以空间换时间的办法,用一个map数组来存放元素的计数。时间复杂度为O(n),空间复杂度为O(n)&#include &stdio.h&
#include &stdlib.h&
#include &string.h&
int main()
int n, i, j, count = 0;
//n is The length of the Array
while (scanf(&%d&, &n) != EOF)
int *a = malloc(sizeof(int) * n);
int *map = malloc(sizeof(int) *n);
memset(map, 0, sizeof(map));
for (i = 0; i & i++)
scanf(&%d&, &a[i]);
for (i = 0; i & i++)
map[a[i]]++;
for (i = 0; i & i++)
if (map[i] == 0)
printf(&%d does not appear in the array!\n&, i);
printf(&%d appear in the array for %d times\n&, i, map[i]);
&&但上述解法都不满足题目对时间复杂度和空间复杂度的要求,因此我们想到重复利用数组A。解法三:& & & 三次遍历数组的方法:& & & & & 第一次遍历:对于每一个A[i] = A[i] * n& & & & & 第二次遍历:对于每一个i, A[A[i]/n]++& & & & & 第三次遍历:对于每一个i,A[i]%n就是i出现的次数解释:A[i]应该出现在A中的A[i]位置,乘以n、再除以n,很容易来回变换;第二次遍历,对于A[i]本来所在的位置不断增1,但绝不超出n,那么每一个i出现的次数,就是A[I]对n取余。&#include &stdio.h&
#include &stdlib.h&
int main()
//n is The length of the Array
while (scanf(&%d&, &n) != EOF)
int *a = malloc(sizeof(int) * n);
for (i = 0; i & i++)
scanf(&%d&, &a[i]);
for (i = 0; i & i++)
a[i] = a[i] *
for (i = 0; i & i++)
a[a[i]/n]++;
for (i = 0; i & i++)
if (a[i] % n == 0)
printf(&%d does not appear in the array!\n&, i);
printf(&%d appear in the array for %d times\n&, i, a[i]%n);
&&解法四:& & 两次遍历数组的方法:考虑A[i],现在的位置为i,如果采用A来计数,它的位置应该是A[i]%n,找到计数位置,处理这个计数位置的办法就是加n.& & & &第一次遍历:对A[i]的计算位置加n,加n可以保证A[i]%n的是不变的& & & &第二次遍历:A数组,最后每一个元素表示为A[i] = x + k * 其中x&n,并且k就是我们要统计的频率&#include &stdio.h&
#include &stdlib.h&
int main()
//n is The length of the Array
while (scanf(&%d&, &n) != EOF)
int *a = malloc(sizeof(int) * n);
for (i = 0; i & i++)
scanf(&%d&, &a[i]);
for (i = 0; i & i++)
a[a[i] % n] +=
for (i = 0; i & i++)
if (a[i] / n == 0)
printf(&%d does not appear in the array!\n&, i);
printf(&%d appear in the array for %d times\n&, i, a[i]/n);
&&就爱阅读www.92to.com网友整理上传,为您提供最全的知识大全,期待您的分享,转载请注明出处。
欢迎转载:
推荐:    

我要回帖

更多关于 for循环遍历数组 的文章

 

随机推荐