标题:堆的问题错在哪里??
取消只看楼主
哈哈鱼
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2006-3-12
 问题点数:0 回复次数:0 
堆的问题错在哪里??
#include<stdio.h>
#include<stdlib.h>
struct heap{
int*data;
//定义堆的数组域的指针
int length;
//定义堆的长度指针
int rear;
//定义堆尾指针
};//定义一个堆类型
void inint(struct heap**bt,int n)
//初始化堆
{
(*bt)->data=malloc(sizeof(int)*n);
//分配堆空间并使头指针指向此段内存
(*bt)->length=0;
(*bt)->rear=0;
}
void insert(struct heap *bt,int x)//向堆中插入一个新的元素
{
int i,temp,j;
bt->rear++;
bt->length++;
bt->data[bt->rear]=x;
//将新元素赋到堆尾
i=bt->rear;
for(;i!=1;){
j=i/2;
if(bt->data[i]>bt->data[j]){
temp=bt->data[i];
bt->data[i]=bt->data[j];
bt->data[j]=temp;
i=j;
}
else break;
}
//调整新的堆的排列,使其符合大根堆的特点
}
void print(struct heap* bt)
{
int i;
if(bt){
for(i=1;i<=bt->length;++i)
printf("%d",bt->data[i]);
}
}
main()
{
struct heap*bt;
int a[5]={2,4,6,23,32};
int i,n;
scanf("%d",&n);
inint(&bt,n);
for(i=0;i<5;++i)
insert(bt,a[i]);
print(bt);
printf("\n");
free(bt);
}
这个程序不知道为什么在TC下运行正确,但是在VC下却说指令引用了不能写的内存。这个程序调用内存到底错在哪里??
搜索更多相关主题的帖子: include insert 空间 元素 
2006-05-21 17:43



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-66048-1-1.html




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

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