| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 789 人关注过本帖
标题:请帮我看看这个折半插入排序出了什么问题??非常谢谢!!
取消只看楼主 加入收藏
傲视
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-9-7
结帖率:100%
收藏
 问题点数:0 回复次数:1 
请帮我看看这个折半插入排序出了什么问题??非常谢谢!!
#include<stdio.h>
#include<malloc.h>
void main()
{
 int*a;
 int num,low=1,j,high,length=2,m;
 a=(int *)malloc(100*sizeof(int));
 a[0]=2;a[1]=6;
 while(1)
 {
  scanf("%d",&num);
  if(num==0)break;
  low=1;high=length;
  while(low<=high)
  {
   m=(low+high)/2;
   if(a[m]>num) high=m-1;
   else low=m+1;
  }
  for( j=length;j>=m;--j)a[j+1]=a[j];
  a[m]=num;
 
  length++;
  printf("\n");
 }
  for(int i=0;i<length;i++)printf("%3d",a[i]);
}
/*(插入开头的先不考虑。还没完善好,先解决这个问题。。谢谢!)我想输入整数(以0结束),以插入的方式放到数组中,按大小排列。如输入2 3 8 4
则输出2 2 3 4 6 8*/
搜索更多相关主题的帖子: 折半 
2009-10-16 16:10
傲视
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-9-7
收藏
得分:0 
回复 4楼 lianxuchun
谢谢!!!由学到东西了!!
2009-10-19 15:42
快速回复:请帮我看看这个折半插入排序出了什么问题??非常谢谢!!
数据加载中...
 
   



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

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