zoukankan      html  css  js  c++  java
  • 第五十八题(从尾到头输出链表)

    58.从尾到头输出链表。
    题目:输入一个链表的头结点,从尾到头反过来输出每一个结点的值。


    思路:题不难,提供几种思路

    1.使用栈的先进后出特性实现,遍历链表元素依次入栈,再出栈就可以达到目的

    2.使用数组先暂存顺序遍历的结果,再对数组反向遍历就可以。

    3.递归,也就是这里採用的方法。

    C++代码:

    #include "stdafx.h"
    #include<ctime>
    #include<iostream>
    namespace MS100P_58
    {
    	void reversePrintList(node* p)
    	{
    		if (p == NULL)	return;
    		reversePrintList(p->next);
    		cout << p->data << ' ';
    	}
    	void test()
    	{
    		node *head = createList(20);
    		printList(head);
    		reversePrintList(head->next);
    		cout << endl;
    		deleteList(head);
    	}
    }
    int _tmain(int argc, _TCHAR* argv[])
    {
    	MS100P_58::test();
    	return 0;
    }

    执行结果:


    附測试代码中用到的创建,打印,删除链表的函数

    struct node
    {
    	int data;
    	node* next;
    };
    node* createList(int len)                                                      //创建链表
    {
    	node* head = new node();
    	node* pCurrent = head;
    	srand(time(0));
    	for (int i = 0; i < len; i++)
    	{
    		pCurrent->next = new node();
    		pCurrent = pCurrent->next;
    		pCurrent->data = rand() % 100;
    
    	}
    	pCurrent->next = NULL;
    
    	return head;
    }
    void deleteList(node *p)
    {
    	node*q;
    	while (p != NULL)
    	{
    		q = p;
    		p = p->next;
    		delete q;
    	}
    }
    void printList(node * head)                                                                 //打印输出链表内容
    {
    	node* p = head->next;
    	while (NULL != p)
    	{
    		cout << p->data << ' ';
    		p = p->next;
    	}
    	cout << endl;
    }


  • 相关阅读:
    CSS—BFC学习
    JS函数声明及函数表达式相关
    你想要的正则表达式笔记
    WordPress搭建自己的网站
    声纹识别
    WordPress搭建自己的网站
    L--jsp和servlet
    L--网页跳转
    L1--指针
    L--Java关键字final、static
  • 原文地址:https://www.cnblogs.com/llguanli/p/6913932.html
Copyright © 2011-2022 走看看