标题:帮编个程序呗 : 将不带头节点的单链表就地逆置
只看楼主
罗尼
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2009-8-17
结帖率:100%
已结贴  问题点数:100 回复次数:5 
帮编个程序呗 : 将不带头节点的单链表就地逆置
用C语言编啊

这好像是个考研题啊
搜索更多相关主题的帖子: 头节点 逆置 单链表 C语言 数据结构 
2009-08-18 22:15
shanbiao
Rank: 2
等 级:论坛游民
帖 子:11
专家分:44
注 册:2009-8-19
得分:20 
网上好多,可以去下。书上也有,接几本数据结构的书来看看
2009-08-19 13:04
mango62
Rank: 2
等 级:论坛游民
帖 子:16
专家分:65
注 册:2009-4-12
得分:60 
typedef int data;

typedef struct _Node{
     data  elem;
    _Node  *next;
}Node,*pNode;

/*
*传入单向链表的第一个节点的二级指针
*该函数执行后将更新该二级指针P指向倒转
*后链表的启示指针
*/
int inversion_list(pNode *p)
{  
    int result=0;

    /*空链表*/
    if(!p || !(*p))
        result = -1;
   
    /*保存当前节点及下个节点*/
    pNode pCTemp = *p;
    pNode pNTemp = (*p)->next;

    /*第一个节点将成为最后一个节点*/
    (*p)->next = NULL;
   
    /*依次进行倒转处理*/
    while(pNTemp)
    {   
        pNode pNNTemp = pNTemp->next;

        /*倒转当前处理的相邻节点*/
        pNTemp->next = pCTemp;
        
        /*更新下次倒转处理的节点信息*/
        pCTemp = pNTemp;
        pNTemp = pNNTemp;
    }
    /*返回新的首节点*/
    *p = pCTemp;

    return result;
}

[ 本帖最后由 mango62 于 2009-8-22 20:19 编辑 ]
2009-08-22 20:00
lwcompany
Rank: 2
等 级:论坛游民
帖 子:7
专家分:20
注 册:2009-8-18
得分:20 
用二分查找思想进行置换试一下,
2009-08-31 16:10
lwcompany
Rank: 2
等 级:论坛游民
帖 子:7
专家分:20
注 册:2009-8-18
得分:0 
用二分查找法的思想进行置换,我认为可以的
2009-08-31 16:12
hwdwow
Rank: 2
等 级:论坛游民
帖 子:119
专家分:98
注 册:2009-3-21
得分:0 
考研题太简单了把。我初中自学编程的随便就写出了。
typedef struct node
{
    int data;
    struct node *next;
}Node;

Node *ReverseList(Node *h)
{
    Node *p=h,*q;
    h=NULL;
    while(p)
    {
        q=p->next;
        p->next=h;
        h=p;
        p=q;
    }
    return h;
}
2009-09-08 06:51



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




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

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