文章目录

  • 从尾到头打印链表
  • 回文链表

从尾到头打印链表

link.

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

示例 1:

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

int* reversePrint(struct ListNode* head, int* returnSize)
{if(head==NULL){*returnSize=0;return NULL;}
//先反转链表
struct ListNode*newhead=NULL,*cur=head,*next=cur->next;
int a=0;
while(cur)
{a++;cur->next=newhead;newhead=cur;cur=next;if(next)next=next->next;
}
int *ret=(int *)malloc(sizeof(int)*a);//开辟数组来接收newnode的值
for(int i=0;i<a;i++)
{ret[i]=newhead->val;newhead=newhead->next;
}
*returnSize=a;
return ret;
}

回文链表

link.

给定一个链表的 头节点 head ,请判断其是否为回文链表。

如果一个链表是回文,那么链表节点序列从前往后看和从后往前看是相同的。

示例 1:

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

示例 2:

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

提示:

链表 L 的长度范围为 [1, 105]
0 <= node.val <= 9

思路

1221,我们先找到中间节点,然后再把mid进行后面链表进行反转 ,再一一比较,如果一条到空都相同则为真,有一个不同就是假
如1221,就是12和1221进行比较,都相同
或则12321,12321和123进行比较

struct ListNode*midnode(struct ListNode*head)//找中间节点
{struct ListNode*fast=head,*slow=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;}return slow;
}struct ListNode* reverse(struct ListNode*head)//反转链表
{struct ListNode*newhead=NULL;struct ListNode*cur=head;struct ListNode*next=cur->next;while(cur){cur->next=newhead;newhead=cur;cur=next;if(next)next=next->next;}
return newhead;
}bool isPalindrome(struct ListNode* head)
{if(head==NULL)
{return true;
}
struct ListNode*phead=head;
struct ListNode*mid=midnode(phead);
struct ListNode*now=reverse(mid);
while(head&&now)
{if(head->val!=now->val){return false;}head=head->next;now=now->next;
}
return true;
}

运用反转链表的思想实现力扣题相关推荐

  1. 滑动窗口算法框架(Java版)秒杀力扣题(76、567、438、3、485)

    一.声明 1.非常感谢东哥(labuladong)分享了**滑动窗口算法框架**: 2.我在理解了东哥的思想后,用Java实现了滑动窗口算法框架,一来方便自己学习,二来方便一些Java小伙伴: 3.再 ...

  2. 力扣题458:可怜的小猪

    力扣题458:可怜的小猪 有 buckets 桶液体,其中 正好 有一桶含有毒药,其余装的都是水.它们从外观看起来都一样.为了弄清楚哪只水桶含有毒药,你可以喂一些猪喝,通过观察猪是否会死进行判断.不幸 ...

  3. 力扣题【简单级别】1

    2019.9.10 771.宝石与石头 public int numJewelsInStones(String J, String S) {if (J == null || S == null) re ...

  4. 力扣题 <爬楼梯> 递归结合表

    题目描述: 假设你正在爬楼梯.需要 n 阶你才能到达楼顶. 每次你可以爬 1 或 2 个台阶.你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n = 2 输出:2 解释:有两种方法可以爬到楼顶 ...

  5. 力扣题库设计循环队列

    题目要求: 设计你的循环队列实现. 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环.它也被称为"环形缓冲器". 循环队列 ...

  6. 力扣题——2.除数与被除数

    下面,我们来看一道力扣题 题目如下: 需求:给定两个整数,被除数和除数(都是正数,且不超过int范围)将两数相除 要求:不使用乘法.除法和%运算符得到商和余数 分析: 在分析这道题之前,我们先来将一个 ...

  7. leetcode344. 反转字符串 史上最简单力扣题

    编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 char[] 的形式给出. 不要给另外的数组分配额外的空间,你必须原地修改输入数组.使用 O(1) 的额外空间解决这一问题. 你可以 ...

  8. 1025. 反转链表 (25)-浙大PAT乙级真题

    给定一个常数K以及一个单链表L,请编写程序将L中每K个结点反转.例如:给定L为1→2→3→4→5→6,K为3,则输出应该为3→2→1→6→5→4:如果K为4,则输出应该为4→3→2→1→5→6,即最后 ...

  9. 按照日期:蓝桥杯真题、洛谷题单、力扣题单汇总

    2020年 2022.03.23绝世武功 2020.12.26框子求循环数组的m个最大和 2020.12.28暴力三阶幻方 2020.12.29未名湖的烦恼 2021年 2021.01.25包子凑数 ...

最新文章

  1. mysql导出数据到s3_mysql导出数据库几种方法
  2. python中国大学排名爬虫写明详细步骤-python中国大学排名爬虫
  3. 13.5 常见Random类
  4. ACE - Reactor模式源码剖析及具体实现(大量源码慎入)
  5. Linux文件系统简介及常用命令
  6. VS中的调试相关的技巧
  7. CF388C-Fox and Card Game【博弈论,结论】
  8. 【渝粤教育】国家开放大学2018年春季 0050-21T民族理论与民族政策 参考试题
  9. 简单说说JAVA的String和byte[]的关系
  10. entity framework扩展实战,小项目重构,不折腾
  11. 谈谈作为DBA我对MySQL数据库优化的理解
  12. 计算机英语emulated,【英语词汇】 imitate、mimic、mock、 simulate、emulate 这组词都有...
  13. 近期14个“AI产品经理”职位JD推荐(覆盖北京、上海、深圳、成都、重庆、杭州)
  14. windows symbols
  15. PCI与PCIe学习一——硬件篇
  16. 论文笔记:Intention Oriented Image Captions with Guiding Objects
  17. RankNet,LambdaRank,LambdaMart
  18. 联想x1carbon更换电池_联想_ThinkPad|ThinkCentre|ThinkStation服务与驱动下载_常见问题...
  19. 测试数据--Excel 获取百家姓
  20. 解析阿里巴巴为什么选择赴美上市

热门文章

  1. android 注册动态广播 注销_Android学习笔记(十一)BroadcastReceiver动态注册、注销示例...
  2. photoshop2020 选择“主题”后闪退的解决方法
  3. 2017浙江工业大学-校赛决赛 竹之书
  4. 更新win10系统后office打不开的解决方法
  5. 更改计算机硬盘名字,如何修改盘符 – 磁盘及光驱名称错乱,教你怎么更改回来...
  6. CVPR2021 | AttentiveNAS:通过注意力采样改善神经架构搜索
  7. 计算机辅助教育中的评价标准有,计算机辅助教育习题集
  8. 六招搞定你爱的坏男人
  9. c语言经典程序100例 - 百度,经典C语言程序100例(51-80)_绝望之家_百度空间
  10. Python 学习 求圆面积和周长