| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1423 人关注过本帖
标题:在数组中插入一个数字(求大神)
只看楼主 加入收藏
helloUJS
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:168
专家分:731
注 册:2013-3-27
收藏
得分:3 
假设a[0],a[1],...,a[n-1]已经按升序排列,现在将数据x插入到数组中,使得a[0],a[1],....,a[n-1],a[n]仍然保持升序,代码:
j=n-1;
while(j>=0&&x<a[j])
{ a[j+1]=a[j];j--;}
a[j+1]=x;
2015-04-27 23:53
AleTiff
Rank: 3Rank: 3
等 级:论坛游侠
威 望:4
帖 子:64
专家分:157
注 册:2015-3-30
收藏
得分:3 


这种就事论事的例子,确实是怎么弄都可以的。但项目里你也是这么解决的话,估计项目组会为你专门配备一名代码审核员。

首先,问题显然需要对存储区域做动态分配,所以,可以写成一个两参数的函数:输入已经排序完成的数列和待插入的数据,返回已排序的数列。

第二,既然这个输入里已经存在了一个已排序数列,插入显然可以使用二分法快速插入。

第三,为让上述两项顺利完成,排序数列在初始化或者声明的时候就要为这个目的做好准备,比如本身支持动态分配、尾部已经添加结束标志等等。
2015-04-29 11:53
陆思雨
Rank: 2
等 级:论坛游民
威 望:1
帖 子:36
专家分:42
注 册:2014-9-17
收藏
得分:3 
回复 12楼 AleTiff
什么是二分法啊?
2015-04-29 14:21
快速回复:在数组中插入一个数字(求大神)
数据加载中...
 
   



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

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