十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
一般这样的题,链表肯定不会是一个双向链表还带个循环什么的,也就是只给一个单链表的头结点,然后从尾到头输出每个结点的值;
公司主营业务:网站制作、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出正定免费做网站回馈大家。如果从前往后去找最后一个结点,那找到了输出然后就没办法往返回往头部访问了,因为只是个单链表;因此可以想到,用递归来实现:
#includeusing namespace std; template //将链表的结点定义为模板类,实现代码的复用性 struct ListNode { T _data; ListNode * _next; }; template ListNode * buy_node(T data) //创建结点 { ListNode * tmp = new ListNode ; tmp->_data = data; tmp->_next = NULL; return tmp; } template void init_list(ListNode ** node, T data) //链表的初始化 { *node = buy_node(data); } template void push_node(ListNode *& head, T data) //向链表中插入结点 { if(head == NULL) { init_list(&head, data); return; } ListNode * tmp = head; while(tmp->_next != NULL) { tmp = tmp->_next; } tmp->_next = buy_node(data); } template void destroy_list(ListNode *& head) //销毁链表 { if(head != NULL) { ListNode * cur = head; ListNode * tmp = head; while(cur != NULL) { tmp = cur; cur = cur->_next; delete tmp; } head = NULL; } } template void print_list(ListNode * head) //正序打印链表的数据 { while(head != NULL) { cout< _data<<"->"; head = head->_next; } cout<<"NULL"< void ReversePrintList(ListNode * head) //逆序打印链表,用递归 { if(head != NULL) { ReversePrintList(head->_next); cout< _data<<"->"; } else cout<<"NULL->"; } int main() { ListNode * list = NULL; push_node(list, 1); push_node(list, 2); push_node(list, 3); push_node(list, 4); push_node(list, 5); push_node(list, 6); push_node(list, 7); push_node(list, 8); push_node(list, 9); cout<<"print list: "; print_list(list); cout<<"reverse print list: "; ReversePrintList(list); cout< 上面的栗子中只为了完成题目要求并没有实现链表的其他操作,比如pop数据以及查找删除插入等函数,运行程序可得如下结果:
从上面的程序可以知道,将链表逆序输出其实就是后插入的结点先输出,最开始放进去的结点最后输出,因此也就是后进先出的原则,可以用栈来实现,从头开始遍历链表,将结点一一push_back进栈里面,然后再从栈顶取出数据,取到的就是链表的最后一个结点,再不断地pop数据然后取栈顶;
上面的程序中用的是非类的变量,下面可以定义一个链表类来实现,而且当程序运行完后不用手动调用析构函数释放空间:
#include#include using namespace std; template struct ListNode //链表结点结构体 { T _data; ListNode * _next; ListNode(T data) :_data(data) ,_next(NULL) {} }; template class List //实现一个链表类 { public: List() //默认构造函数 :_head(NULL) {} List(T data) //带参的构造函数 :_head(new ListNode (data)) {} ~List() //析构函数,释放链表结点空间 { if(_head != NULL) { ListNode * tmp = _head; ListNode * cur = _head; while(cur != NULL) { tmp = cur; cur = cur->_next; delete tmp; } _head = NULL; } } void _push(T data) //在链表尾部push数据 { if(_head == NULL) { _head = new ListNode (data); return; } ListNode * tmp = _head; while(tmp->_next != NULL) tmp = tmp->_next; tmp->_next = new ListNode (data); } void print_list() //正序输出链表 { ListNode * tmp = _head; while(tmp != NULL) { cout< _data<<"->"; tmp = tmp->_next; } cout<<"NULL"< list; ListNode * tmp = _head; while(tmp != NULL) //将链表结点依次放入栈中 { list.push_back(tmp->_data); tmp = tmp->_next; } cout<<"reverse print list:"< "; list.pop_back(); } cout<<"NULL"< * _head; }; int main() { List list(1); list._push(2); list._push(3); list._push(4); list._push(5); list._push(6); list._push(7); list._push(8); list._push(9); list.print_list(); list.ReversePrintList(); return 0; } 运行程序可得如下结果:
《完》
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章标题:输入一个链表的头结点,从尾到头反过来打印每个结点的值——5-创新互联
网站链接:http://mswzjz.cn/article/dijosp.html