| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 463 人关注过本帖
标题:十万火急!一个优化代码的问题,数组的~~
只看楼主 加入收藏
rayOMG
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2010-10-9
结帖率:83.33%
收藏
已结贴  问题点数:20 回复次数:8 
十万火急!一个优化代码的问题,数组的~~
呵呵,其实也没那么急。。。JUST 4 FUN~~

题目:有7个数存放在一个数组中,从键盘输入1个整数,查找这个数是否在一个已经确定元素的整数数组中,如果在,输出其下标,如果不在,输出0
 
书上写道3种方法,其中第3个方法与第2个方法的比较没看懂~
 
第二种方法的思路(只是部分代码):
scanf("%d",&x);
for(i=n;i>=1;i--)
    if(a[i]==x)
         break;
printf("%d\n",i);
第三种方法的思路(部分代码):
scanf("%d",&x);
a[0]=x;
for(i=n;a[i]!=x;i--);
printf("%d\n",i);
 
没懂的地方就在:书上写道“第三种方法先将a[0]的值赋为x,其目的是免去在查找过程中每一步都要检测数组是否越界的问题,可以提高效率”
 
我的问题就是:
                   检查是否越界是通过写代码实现的还是程序在运行时自己就会检查?如果是写代码实现的,那么第三种方法的a[i]!=x不就没有检查越界吗?
                   如果按照书上的说法,那第三种方法是怎么实现不检查越界的呢?
搜索更多相关主题的帖子: 代码 
2010-10-24 19:22
zghnxzdcx
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:550
专家分:1176
注 册:2010-4-6
收藏
得分:10 
话说,C语言本身,是不检查数组越界的。

书上所说的检查,是你自己在程序中加判断,以判断是否越界

没发现第三种方法的循环体中比前面的方法少做一次判断吗?

你永远不可能战胜一个纯傻子,因为他会把你的智商拉到和他同一个水平,然后用他的丰富经验打败你。
2010-10-24 19:28
rayOMG
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2010-10-9
收藏
得分:0 
发现了。那个跟检不检查越界没什么关系啊
2010-10-24 19:31
rayOMG
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2010-10-9
收藏
得分:0 
哦。。。明白了~~~~谢谢lo!
2010-10-24 19:33
zghnxzdcx
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:550
专家分:1176
注 册:2010-4-6
收藏
得分:0 
i>=1,作为循环控制条件,就是用来检查数组越界的

你永远不可能战胜一个纯傻子,因为他会把你的智商拉到和他同一个水平,然后用他的丰富经验打败你。
2010-10-24 19:33
l302889153
Rank: 2
等 级:论坛游民
帖 子:66
专家分:89
注 册:2010-5-26
收藏
得分:10 
第二个用讲吗?
2010-10-24 19:38
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
C语言不会对数组的边界进行检查。
看起来数组a有n+1个元素。第二种方法里a[0]就没有被利用到。第二种方法中的循环判断项 i>=1就是在检查数组边界,对x值的检查放在循环内。
而第三种方法中a[i]!=x既是循环判断项,也是边界检查项。因为循环在i==0时必然会结束,不会发生越界。结果就是如果在a[n]至a[1]之前存在x的话循环返回相应的下标,否则返回。
在第二种方法中使用了两句判断,而第三种方法只用了一句,效率有所提高。

重剑无锋,大巧不工
2010-10-24 19:43
abc3210cba
Rank: 2
等 级:论坛游民
帖 子:63
专家分:97
注 册:2010-9-26
收藏
得分:0 
第三种因为
a[0]=x;
所以
a[i]!=x最后一定有a[0]=x不可能越界。
假设输入的那个数在且等于a[0]那么输出会是0
假设输入的那个数不在那么也会输出0
所以不管初始的a[0]是否等于输入的数都不影响结果。
所以可以直接写a[0]=x;

2010-10-24 19:45
abc3210cba
Rank: 2
等 级:论坛游民
帖 子:63
专家分:97
注 册:2010-9-26
收藏
得分:0 
还有效率方面完全同意7楼
2010-10-24 19:46
快速回复:十万火急!一个优化代码的问题,数组的~~
数据加载中...
 
   



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

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