zoukankan      html  css  js  c++  java
  • 06从尾到头打印链表

    题目描述:

    输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。

     

    示例 1:

    输入:head = [1,3,2]
    输出:[2,3,1]

    想用栈的方法来实现,可是我目前还没有做很多栈的题,水平有限

    以下是我写的错误的栈的代码:

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     struct ListNode *next;
     * };
     */
    
    
    /**
     * Note: The returned array must be malloced, assume caller calls free().
     */
    
     struct stack
    {
        int val;
        struct ListNode *top;
    };
    int* reversePrint(struct ListNode* head, int* returnSize){
    //如果能用栈来解决的话 会容易很多
    int stack[1000000];
    struct ListNode *p=head;
    while(p!=NULL)
    {
        stack.push(p->val);
        p=p->next;
    }
    while(stack!=empty)
    {
        stack[i]=stack.pop(stack.top());
        stack.pop();
    }
    return stack;
    }
    

      以下是老古董方法,利用数组来辅助实现反转输出

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     struct ListNode *next;
     * };
     */
    
    /**
     * Note: The returned array must be malloced, assume caller calls free().
     */
    int* reversePrint(struct ListNode* head, int* returnSize){
    //如果能用栈来解决的话 会容易很多
    
    struct ListNode *p=head;
    int *a=(int *)malloc(sizeof(int)*10000);
    int n=0;//计算出链表大小
    while(p!=NULL)
    {
       n++;
       p=p->next;
    }
    *returnSize=n;
    p=head;
    while(n--)
    {
        a[n]=p->val;
        p=p->next;
    }
    return a;
    }
    

      反思;

    这个方法并不算是一个优秀的方法,我希望后面做到栈的时候能在回头把这道题重新做一下

  • 相关阅读:
    JS 实现数据分割1,123,456
    JS屏蔽键盘相关事件
    地图坐标转屏幕坐标
    对xml格式的字符串的一些操作
    ListView_Adpter
    单元测试(Android)_JUnit
    调用系统拍照
    获取手机SD卡的剩余容量(MB)
    数据库的基本操作
    临时修改模拟器手机运行内存和手机内存(不是SD卡内存)
  • 原文地址:https://www.cnblogs.com/redzzy/p/13343971.html
Copyright © 2011-2022 走看看