QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4943|回复: 8
打印 上一主题 下一主题

+那位高手帮忙用C写一个将链表反转的递归算法!+

[复制链接]
字体大小: 正常 放大
solucky        

17

主题

1

听众

109

积分

升级  4.5%

该用户从未签到

跳转到指定楼层
1#
发表于 2004-10-18 14:40 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>   帮忙用C写一个将<FONT color=#f70909>链表反转</FONT>的<FONT color=#ff0000>递归</FONT>算法!7 n  I1 n  i' Q$ }: S4 Z; t
   比如:" R6 F6 n4 E& I! k7 N+ W1 a( D4 N
   表原数据这:1 2 3 4
8 ]0 J& S+ a4 Z2 \   计算后的数据为:4 3 2 1</P>% r) e" R6 i8 L7 ^
<>先谢了!</P>6 `% j) M+ f; D7 w+ {$ K& q1 z5 z- S! Y
<>祝大家天天快乐!</P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
笑一笑 只牵动苦涩的嘴角 我的寂寞谁知道 我害怕 用真心面对这世界 只好越来越沉默
ilikenba 实名认证       

1万

主题

49

听众

2万

积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    <>我说说算法的思路,下面的是思路可以用具体的语言实现:</P><>   首先定义你的链表结构体,和一个可以存储链表结构的栈。</P><>  main()</P><>{  </P><> searchnext;</P><> make;//从栈里面依次弹出节点形成一个新的链表,就是所求的链表!</P><>}</P><>function searchnext;</P><>{</P><>  read;//读入一个链表节点的函数。</P><>  store;//将这个节点的信息压入栈。</P><>  if( islast ==true)//如果本节点是最后的节点。</P><>{</P><>    store;//将这个节点的信息压入栈.</P><>}</P><>else</P><>{</P><>    searchnext;</P><>}</P><>}</P>
    回复

    使用道具 举报

    xShandow        

    43

    主题

    1

    听众

    385

    积分

    升级  28.33%

    该用户从未签到

    国际赛参赛者

    新人进步奖

    <>这个很简单啊。你用两个链表,相互替换一下,再把替换后的表的元素付给第一个链表不就可以实现倒序了吗?</P>
    回复

    使用道具 举报

    ilikenba 实名认证       

    1万

    主题

    49

    听众

    2万

    积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    回复

    使用道具 举报

    无名        

    5

    主题

    1

    听众

    68

    积分

    升级  66.32%

    该用户从未签到

    新人进步奖

    <>preNode = NULL;</P>
    3 U4 a' Z; ^5 `1 [4 n" J0 T<>node = list-&gt;Fitst;</P># \( i# x0 F3 R0 W; [9 F  f( W! A
    <>while(node != NULL )</P>" W: D! j+ {( x
    <>{</P>) E+ i( L( n- i0 I- H
    <>    tempNode = node-&gt;next;</P>0 t9 e1 N' l" t! F8 ~
    <>    node-&gt;Next = preNode;</P>: k2 \* m' U# ~! U0 P2 r) b
    <>    preNode = node;</P>6 |1 c$ }& }) {# O5 n6 m% X7 B, {
    <>    node = tempNode;</P>
    - f/ R% H; N) H4 A. A" l, D9 ?' d, B<>}</P>
    ) _. i, E/ ?+ J% v2 u7 e( V$ v' R
    [此贴子已经被作者于2004-10-20 20:09:40编辑过]
    回复

    使用道具 举报

    ilikenba 实名认证       

    1万

    主题

    49

    听众

    2万

    积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    <>楼上的方法是将链表的前后的指针交换了位置,值得推荐,但是没有用递归呀!</P>
    回复

    使用道具 举报

    无名        

    5

    主题

    1

    听众

    68

    积分

    升级  66.32%

    该用户从未签到

    新人进步奖

    <>不好意思没有看见递归,循环改递归最容易不过啦</P><>void Reverse(List * list, Node * preNode)</P><>{</P><>    Node * node = list-&gt;First();</P><>    if(node != NULL &amp;&amp; node-&gt;next != NULL)</P><>    {</P><>        Node * tempNode = node-&gt;next;</P><>        node-&gt;Next = preNode;</P><>        list-&gt;SetHead(tempNode);</P><>        Reverse(list, node);</P><>    }</P><>}</P><>调用时只要:Reverse(list, NULL);</P>
    回复

    使用道具 举报

    realyoyy        

    1

    主题

    2

    听众

    38

    积分

    升级  34.74%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

    ilikenba 实名认证       

    1万

    主题

    49

    听众

    2万

    积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-14 17:06 , Processed in 0.509599 second(s), 96 queries .

    回顶部