题目

输入一个链表的头结点,按照 从尾到头 的顺序返回节点的值。
返回的结果用数组存储。

样例

输入:[2, 3, 5]
返回:[5, 3, 2]

方法一:

/* struct ListNode {int val;  //当前结点的值ListNode *next;  //指向下一个结点的指针ListNode(int x) : val(x), next(NULL) {}  //初始化当前结点值为x,指针为空};
*/class Solution {public:vector[HTML_REMOVED] printListReversingly(ListNode* head) {vector [HTML_REMOVED] res;while(head) {res.push_back(head->val);head=head->next;
}return vector<int>(res.rbegin(), res.rend());    //不能使用res.end() 倒序只能使用倒序的}
};

心得

return vector(res.rbegin(), res.rend()); 与 return vector(res.end()-1, res.begin()-1);

附录1 ListNode

struct ListNode {
int val; //当前结点的值
ListNode *next; //指向下一个结点的指针
ListNode(int x) : val(x), next(NULL) {} //初始化当前结点值为x,指针为空
};

附录2 vector使用

介绍

  1. vector是表示可变大小数组的序列容器。
  2. 就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问,和数组一样高效。但是又不像数组,它的大小是可以动态改变的,而且它的大小会被容器自动处理。
  3. 本质讲,vector使用动态分配数组来存储它的元素。当新元素插入时候,这个数组需要被重新分配大小为了增加存储空间。其做法是,分配一个新的数组,然后将全部元素移到这个数组。就时间而言,这是一个相对代价高的任务,因为每当一个新的元素加入到容器的时候,vector并不会每次都重新分配大小。
  4. vector分配空间策略:vector会分配一些额外的空间以适应可能的增长,因为存储空间比实际需要的存储空间更大。不同的库采用不同的策略权衡空间的使用和重新分配。但是无论如何,重新分配都应该是对数增长的间隔大小,以至于在末尾插入一个元素的时候是在常数时间的复杂度完成的。
  5. 因此,vector占用了更多的存储空间,为了获得管理存储空间的能力,并且以一种有效的方式动态增长。
    与其它动态序列容器相比(deques, lists and forward_lists), vector在访问元素的时候更加高效,在末尾添加和删除元素相对高效。对于其它不在末尾的删除和插入操作,效率更低。比起lists和forward_lists统一的迭代器和引用更好。

用法

  1. 头文件

    #include<vector>
    
  2. vector声明及初始化

    vector<int> vec;        //声明一个int型向量
    vector<int> vec(5);     //声明一个初始大小为5的int向量
    vector<int> vec(10, 1); //声明一个初始大小为10且值都是1的向量
    vector<int> vec(tmp);   //声明并用tmp向量初始化vec向量
    vector<int> tmp(vec.begin(), vec.begin() + 3);  //用向量vec的第0个到第2个值初始化tmp
    int arr[5] = {1, 2, 3, 4, 5};
    vector<int> vec(arr, arr + 5);      //将arr数组的元素用于初始化vec向量//说明:当然不包括arr[4]元素,末尾指针都是指结束元素的下一个元素,//这个主要是为了和vec.end()指针统一。
    vector<int> vec(&arr[1], &arr[4]); //将arr[1]~arr[4]范围内的元素作为vec的初始值
    
  3. vector基本操作

(1). 容量

 向量大小: vec.size();向量最大容量: vec.max_size();更改向量大小: vec.resize();向量真实大小: vec.capacity();向量判空: vec.empty();减少向量大小到满足元素所占存储空间的大小: vec.shrink_to_fit(); //shrink_to_fit

(2). 修改

多个元素赋值: vec.assign(); //类似于初始化时用数组进行赋值
末尾添加元素: vec.push_back();
末尾删除元素: vec.pop_back();
任意位置插入元素: vec.insert();
任意位置删除元素: vec.erase();
交换两个向量的元素: vec.swap();
清空向量元素: vec.clear();

(3)迭代器

开始指针:vec.begin();
末尾指针:vec.end(); //指向最后一个元素的下一个位置
指向常量的开始指针: vec.cbegin(); //意思就是不能通过这个指针来修改所指的内容,但还是可以通过其他方式修改的,而且指针也是可以移动的。
指向常量的末尾指针: vec.cend();

(4)元素的访问

下标访问: vec[1]; //并不会检查是否越界
at方法访问: vec.at(1); //以上两者的区别就是at会检查是否越界,是则抛出out of range异常
访问第一个元素: vec.front();
访问最后一个元素: vec.back();
返回一个指针: int* p = vec.data(); //可行的原因在于vector在内存中就是一个连续存储的数组,所以可以返回一个指针指向这个数组。这是是C++11的特性。

(4)算法

遍历元素
vector::iterator it;
for (it = vec.begin(); it != vec.end(); it++)
cout << *it << endl;
//或者
for (size_t i = 0; i < vec.size(); i++) {
cout << vec.at(i) << endl;
}
元素翻转
#include
reverse(vec.begin(), vec.end());
元素排序
#include
sort(vec.begin(), vec.end()); //采用的是从小到大的排序
//如果想从大到小排序,可以采用上面反转函数,也可以采用下面方法:
bool Comp(const int& a, const int& b) {
return a > b;
}
sort(vec.begin(), vec.end(), Comp);

AcWing之从尾到头打印链表相关推荐

  1. 剑指offer:面试题06. 从尾到头打印链表

    题目:从尾到头打印链表 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回). 示例 1: 输入:head = [1,3,2] 输出:[2,3,1] 限制: 0 <= 链表长度 & ...

  2. 【剑指Offer专题】链表系列:从尾到头打印链表、反转链表、回文链表、合并两个排序的链表(C++和Python实现)...

    关注上方"深度学习技术前沿",选择"星标公众号", 资源干货,第一时间送达! 剑指Offer(三):从尾到头打印链表 输入一个链表的头节点,从尾到头反过来返回每 ...

  3. 《LeetCode力扣练习》剑指 Offer 06. 从尾到头打印链表 Java

    <LeetCode力扣练习>剑指 Offer 06. 从尾到头打印链表 Java 一.资源 题目: 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回). 示例 1: 输入: ...

  4. java从尾到头打印链表数据_Java编程实现从尾到头打印链表代码实例

    问题描述:输入一个链表的头结点,从尾巴到头反过来打印出每个结点的值. 首先定义链表结点 public class ListNode { int val; ListNode next = null; L ...

  5. JAVA实现从尾到头打印链表(《剑指offer》)

    最近在刷<剑指offer>里的编程题,但是网上关于<剑指offer>的解答多半是C或者C++的,而且官方(作者)也是在用C++进行讲解,这里自己用java写了一些题目的解答代码 ...

  6. 【剑指Offer】从尾到头打印链表

    剑指Offer 从尾到头打印链表 题目描述 解法1 实现代码 一点补充 题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 解法1 这道题主要思路是while循环从头遍历整个列 ...

  7. 剑指Offer - 九度1511 - 从尾到头打印链表

    剑指Offer - 九度1511 - 从尾到头打印链表2013-11-29 21:08 题目描述: 输入一个链表,从尾到头打印链表每个节点的值. 输入: 每个输入文件仅包含一组测试样例. 每一组测试案 ...

  8. LeetCode-剑指 Offer 06. 从尾到头打印链表

    剑指 Offer 06. 从尾到头打印链表 思路一:翻转 1:用vector存从头到尾的每个节点值 2:返回时候用reverse翻转一下 时间复杂度:O(n) 空间复杂度:O(n) /*** Defi ...

  9. 剑指offer06.从尾到头打印链表

    剑指offer06.从尾到头打印链表 1. 改变链表结构的解法 2.可以使用栈,递归,或者直接反向输出数组 提示: 若是面试遇到此题,最好先向面试官确认是否可以改变链表的结构, 1. 改变链表结构的解 ...

最新文章

  1. 企业级 CICD 工具部署 Serverless 应用的落地实践
  2. oracle启动crs要多久,ORACLE RAC crs 无法启动
  3. android6.0的坑
  4. mysql之调优概论
  5. Javascript、Dom、JQuery
  6. 手把手教你Axure-基本工具栏
  7. python就业方向-为什么这么多人喜欢Python?Python的就业方向是什么?
  8. Kafka从上手到实践 - 初步认知:MQ系统 | 凌云时刻
  9. 论文阅读SG-PBFT: a Secure and Highly Efficient Blockchain PBFT Consensus Algorithm for IoV
  10. oracle11g 网页账号,oracle11g 创建用户并受权
  11. Java自学路线总结
  12. 互联网金融保弘实业理财投资|白领理财有哪些窍门
  13. 无GPU条件下安装caffe
  14. python透视变换原理_python cv2中的透视变换
  15. 使用expdp(非本地)远程导出数据
  16. 【python核心编程笔记+习题】-CH5-数字类型
  17. 工具 | RaiDrive—将网盘映射为磁盘
  18. 构建基于Jenkins + Github的持续集成环境
  19. 维克森林大学计算机科学专业好不好,维克森林大学商业分析硕士怎么样?
  20. 国际刑警组织:打击网络数字犯罪需全球协作

热门文章

  1. linux-0.11内核 调试教程+GCC源代码
  2. ACM/ICPC 之 四道MST-Prim解法(POJ1258-POJ1751-POJ2349-POJ3026)
  3. Little Alchemy 游戏 - 扒答案。。 Java
  4. uva 10635 Prince and Princess(LCS成问题LIS问题O(nlogn))
  5. jQuery心得5--jQuery深入了解串讲1
  6. 感觉stm32太简单是一种自负吗?
  7. 听说有人不了解柔性数组
  8. HT68F30控制5150 IIC控制总线
  9. MDK中利用宏定义__DATE__和__TIME__设置产品的代码固件版本
  10. Linux下XPath对xml解析