| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 655 人关注过本帖
标题:大根堆中插入一个键,下面是我的错误代码,求大神指点
只看楼主 加入收藏
Johnhdb
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2011-11-15
结帖率:50%
收藏
已结贴  问题点数:5 回复次数:2 
大根堆中插入一个键,下面是我的错误代码,求大神指点
#include<stdio.h>
void swap(int *m,int *n)
{
    int temp;
    temp=*m;
    *m=*n;
    *n=temp;
}
int main()
{
    int a[]={ 0,9,6,8,2,5,7};
    int size=7;
     a[8]=10;//增加一个键
    for(int hole=size+1;hole>1;hole=hole/2){
        if(a[size+1]>a[(size+1)/2])//增加的键与其父节点比较
            swap(&a[size+1],&a[(size+1)/2]);//若大于则交换
    }
    return 0;
}

搜索更多相关主题的帖子: return 
2012-12-31 16:27
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:5 
int main()
 {
     int a[]={ 0,9,6,8,2,5,7}; // 这样你最多可以访问到a[6]的,a[7]之后就是非法内存访问了
     int size=7;
      a[8]=10;//增加一个键 非法内存访问
     for(int hole=size+1;hole>1;hole=hole/2){ // 这个时候size =7 size +1 = 8,
         if(a[size+1]>a[(size+1)/2])//增加的键与其父节点比较 // a[8] 已经是非法内存访问了
             swap(&a[size+1],&a[(size+1)/2]);//若大于则交换
     }
     return 0;
 }

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2012-12-31 16:48
Johnhdb
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2011-11-15
收藏
得分:0 
回复 2楼 yuccn
c语言学的很烂,没有看懂这个伪代码,求指点,我就是不会将伪代码转换成可执行代码
/*伪代码:
HEAP_MOVE_UP(HEAP,i)
    n<-i                         //n指向当前结点
    p<-PARENT[n]                 //p指向父亲结点
    node<-HEAP[i]                //node为临时变量
    while p<>1 and node>HEAP[p]   //当p不为父结点且当前结点比父结点大时移动结点
        HEAP[n]<-HEAP[p]
        n<-p
        p<-PARENT[p]
    HEAP[n]=node

HEAP_INSERT(HAEP,data)
    heap_size<-heap_size+1        //将data插入堆中的最后一个位置
    HEAP[heap_size]<-data
    HEAP_MOVE_UP(HEAP,heap_size)  //对新加入的元素进行上移调整*/



[ 本帖最后由 Johnhdb 于 2012-12-31 17:33 编辑 ]
2012-12-31 17:15
快速回复:大根堆中插入一个键,下面是我的错误代码,求大神指点
数据加载中...
 
   



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

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