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

    题目描述

    输入一个链表,按链表从尾到头的顺序返回一个ArrayList。
     
    栈思路:
    /**
    *  struct ListNode {
    *        int val;
    *        struct ListNode *next;
    *        ListNode(int x) :
    *              val(x), next(NULL) {
    *        }
    *  };
    */
    class Solution {
    public:
        vector<int> printListFromTailToHead(ListNode* head) {
            vector <int> value;
            ListNode *p=NULL;
            p=head;
            stack <int> stk;
            while (p!=NULL){
                stk.push(p->val);
                p=p->next;
            }
            while (!stk.empty()){
                value.push_back(stk.top());
                stk.pop();
            }
            return value;
        }
    };
    #数组翻转 数组翻转可以用c++自带的函数,也可以自己实现
    /**
    *  struct ListNode {
    *        int val;
    *        struct ListNode *next;
    *        ListNode(int x) :
    *              val(x), next(NULL) {
    *        }
    *  };
    */
    class Solution {
    public:
        vector<int> printListFromTailToHead(ListNode* head) {
            vector <int> value;
            ListNode *p=NULL;
            p=head;
            while (p!=NULL){
                value.push_back(p->val);
                p=p->next;
            }
            int temp=0;
            int i=0,j=value.size()-1;
            while (i<j){
                temp=value[i];
                value[i]=value[j];
                value[j]=temp;
                i++;
                j--;
                
            }
            return value;
        }
    };
    #递归思路
    /**
    *  struct ListNode {
    *        int val;
    *        struct ListNode *next;
    *        ListNode(int x) :
    *              val(x), next(NULL) {
    *        }
    *  };
    */
    class Solution {
    public:
        vector< int> value;
        vector<int> printListFromTailToHead(ListNode* head) {
            ListNode *p=NULL;
            p=head;
            if (p!=NULL){
                if (p->next!=NULL){
                    printListFromTailToHead(p->next);
                }
                value.push_back(p->val);
            }
            return value;
        }
    };
     
     
     
     
     
     
  • 相关阅读:
    35美元的树莓派电脑 黑客就偷走了NASA的火星数据
    博客样式保留
    某社交网站XSS小计
    c# WhereIf 扩展
    SQL、Linq、lamda表达式 同一功能不同写法
    tomcat org.apache.coyote.http11.HeadersTooLargeException: 尝试将更多数据写入响应标头,而不是缓冲区中有可用空间。 增加连接器上的maxHttpHeaderSize或将更少的数据写入响应头。
    Maven Dependency Scopes
    为什么mysql中不应该使用utf8编码
    springmvc dispacher中的url-pattern的/和/*区别
    在jsp中java代码中警告Cannot resolve method "XX"
  • 原文地址:https://www.cnblogs.com/hrnn/p/13338558.html
Copyright © 2011-2022 走看看