| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 398 人关注过本帖
标题:给链表排顺序,我这个哪里错了?
只看楼主 加入收藏
神的弃物
Rank: 1
等 级:新手上路
帖 子:7
专家分:5
注 册:2009-8-7
结帖率:100%
收藏
 问题点数:0 回复次数:0 
给链表排顺序,我这个哪里错了?
MailNode *correctorder (MailNode *List,MailNode *temporder)
{
  MailNode *temp=NULL;
  MailNode *tempnext=NULL;
  if (temporder==NULL){
    temp=List;  
    tempnext=temp->next;
   }
    else{
    temp=temporder;  
    tempnext=temp->next;
  }
  while(temp->year<tempnext->year){
    tempnext=tempnext->next;
  }
  temp=tempnext;
  return temp;






      case 'o': case 'O':
        while (i<num){
          if (temp==NULL){ //head
            temp=correctorder(List,temporder);
            temporder=temp;
          }
          else{
            temporder=correctorder(List,temporder);
            temporder=temporder->next;
          }
        i++;
        }
        free(List);
        List=temp;
        break;


老是说segmentation fault.看gdb说我temp->year<tempnext->year错了。这怎么错了?倒是用step一步一步看,发现好像main function里,temp一直为NULL,就像没有return值给他一样,为什么啊?

[ 本帖最后由 神的弃物 于 2009-10-12 19:56 编辑 ]
搜索更多相关主题的帖子: 顺序 链表 
2009-10-12 18:21
快速回复:给链表排顺序,我这个哪里错了?
数据加载中...
 
   



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

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