zoukankan      html  css  js  c++  java
  • 单链表逆转

    单链表逆转(20 分)

    本题要求实现一个函数,将给定的单链表逆转。

    函数接口定义:

    List Reverse( List L );
    

    其中List结构定义如下:

    typedef struct Node *PtrToNode;
    struct Node {
        ElementType Data; /* 存储结点数据 */
        PtrToNode   Next; /* 指向下一个结点的指针 */
    };
    typedef PtrToNode List; /* 定义单链表类型 */
    

    L是给定单链表,函数Reverse要返回被逆转后的链表。

    裁判测试程序样例:

    #include <stdio.h>
    #include <stdlib.h>
    
    typedef int ElementType;
    typedef struct Node *PtrToNode;
    struct Node {
        ElementType Data;
        PtrToNode   Next;
    };
    typedef PtrToNode List;
    
    List Read(); /* 细节在此不表 */
    void Print( List L ); /* 细节在此不表 */
    
    List Reverse( List L );
    
    int main()
    {
        List L1, L2;
        L1 = Read();
        L2 = Reverse(L1);
        Print(L1);
        Print(L2);
        return 0;
    }
    
    /* 你的代码将被嵌在这里 */
    

    输入样例:

    5
    1 3 4 5 2
    

    输出样例:

    1
    2 5 4 3 1


    #include <stdio.h>
    #include <stdlib.h>
    
    typedef int ElementType;
    typedef struct Node *PtrToNode;
    struct Node 
    {
        ElementType Data;
        PtrToNode   Next;
    };
    typedef PtrToNode List;
    
    List Read();
    void Print(List L); 
    
    List Reverse(List L);
    
    int main()
    {
        List L1, L2;
        L1 = Read();
        L2 = Reverse(L1);
        Print(L1);
        Print(L2);
        return 0;
    }
    int n;
    List Read()
    {
        List l;
        l=new Node;
        List tail;
        tail=new Node;
        l->Next =NULL;
        scanf("%d",&n);
        int x;
        scanf("%d",&x);
        l->Data =x;
        l->Next =tail;
        for(int i=2;i<=n;i++)
        {
            scanf("%d",&x);
            tail->Data =x;
            if(i==n) tail->Next =NULL;
            else
            {
                tail->Next =new Node;
            tail=tail->Next ;
            }
        }
        return l;
    }
    
    
    List Reverse(List L)
    {
        PtrToNode old_head,new_head,temp;
    
        old_head=L;
        new_head=NULL;
        while(old_head)
        {
            temp=old_head->Next ;
            old_head->Next =new_head;
            new_head=old_head;
            old_head=temp;
        }
        L=new_head;
        return L;
    }
    
    void Print(List L)
    {
      while(L)
      {
          printf("%d ",L->Data );
          L=L->Next ;
      }
      printf("
    ");
    }
  • 相关阅读:
    WSL中使用npm install报错
    在npm install时node-gyp出现错误
    Chrome禁用隐藏www和m
    Git始终忽略特定文件的某一行内容
    macOS关闭修改扩展名的提示
    解决安装Anaconda后ZSH中使用的依然是系统自带的Python
    macOS上更顺手的终端
    自用的越狱插件
    Tomcat安装后修改路径方法
    TestStack.White安装详解
  • 原文地址:https://www.cnblogs.com/caiyishuai/p/13271069.html
Copyright © 2011-2022 走看看