当前位置: 首页 > news >正文

医院网站建设趋势百度搜索引擎优化案例

医院网站建设趋势,百度搜索引擎优化案例,0元无货源开网店怎么开,著名的深圳网站建设文章目录 一、题目二、C# 题解 一、题目 编写一个函数,检查输入的链表是否是回文的。 点击此处跳转题目。 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true …

文章目录

  • 一、题目
  • 二、C# 题解

一、题目

  编写一个函数,检查输入的链表是否是回文的。

  点击此处跳转题目。

示例 1:

输入: 1->2
输出: false

示例 2:

输入: 1->2->2->1
输出: true

进阶:

  • 你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?

二、C# 题解

  使用 O ( n ) O(n) O(n) 空间很容易写出来,只需要开辟一个数组或者反向链表即可。这里为了实现进阶要求,在原链表上修改。首先将链表的前半部分翻转,然后比较前后两个链表是否相同,最后恢复原链表即可,具体实现细节见代码注释:

/*** Definition for singly-linked list.* public class ListNode {*     public int val;*     public ListNode next;*     public ListNode(int x) { val = x; }* }*/
public class Solution {public bool IsPalindrome(ListNode head) {int n = 0, i;ListNode p = head, q;bool result;// 统计链表长度while (p != null) {p = p.next;n++;}if (n <= 1) return true;    // 长度 <= 1,一定是回文串i = n / 2;                  // 长度的一半,向下取整p = head;while (--i > 0) p = p.next; // 定位到链表中间q = p.next;p.next = null;              // 断开链表Reverse(head);              // 翻转前半部分// 判断链表前后两部分是否相同if (n % 2 == 0) result = Same(p, q);else result = Same(p, q.next); // 奇数长度的链表需要跳过最中间的元素// 恢复链表原状Reverse(p);p.next = q;return result;}// 翻转链表public ListNode Reverse(ListNode head) {ListNode p = null, q = head, r;while (q != null) {r = q.next;q.next = p;p = q;q = r;}return p;}// 比较两个链表是否相同public bool Same(ListNode h1, ListNode h2) {while (h1 != null && h2 != null) {if (h1.val != h2.val) return false;h1 = h1.next;h2 = h2.next;}return h1 == null && h2 == null;}
}
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1)

  看了一下官方解法,发现还可以进行优化。使用快慢指针定位到中间节点,代码会更加高级和优雅hh。但是效率和上面统计长度然后遍历一半进行定位的方式差不多,因为都是遍历了一个半链表(快指针遍历整个链表,慢指针遍历半个链表),但是快慢指针这种方法它显得高级呀哈哈!

/*** Definition for singly-linked list.* public class ListNode {*     public int val;*     public ListNode next;*     public ListNode(int x) { val = x; }* }*/
public class Solution {public bool IsPalindrome(ListNode head) {if (head == null || head.next == null) return true;ListNode p = head, q = p.next; // p:慢指针,q:快指针bool result;while (q != null && q.next != null) {q = q.next.next;           // q 前进两格if (q != null) p = p.next; // q 不为空,p 才前进}ListNode r = p.next;           // 定位到后半段链表的首部p.next = null;                 // 断开链表Reverse(head);                 // 翻转前半部分// 判断链表前后两部分是否相同if (q != null) result = Same(p, r);else result = Same(p, r.next); // 奇数长度的链表需要跳过最中间的元素// 恢复链表原状Reverse(p);p.next = r;return result;}// 翻转链表public ListNode Reverse(ListNode head) {ListNode p = null, q = head, r;while (q != null) {r = q.next;q.next = p;p = q;q = r;}return p;}// 比较两个链表是否相同public bool Same(ListNode h1, ListNode h2) {while (h1 != null && h2 != null) {if (h1.val != h2.val) return false;h1 = h1.next;h2 = h2.next;}return h1 == null && h2 == null;}
}
  • 时间复杂度: O ( n ) O(n) O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1)

  修改过后,发现快慢指针跑出来的速度不如直接统计链表长度来得快。果然,高端的代码往往以最朴素的方法写出来~

http://www.fp688.cn/news/164049.html

相关文章:

  • wordpress源码书籍内蒙古seo
  • 做视频网站用什么好seo站内优化技巧
  • 360网站seo优化怎么做小红书关键词热度查询
  • 曲靖企业网站专业seo培训学校
  • 个人的视频网站如何做seo专员工资待遇
  • 网页制作购物网站企业品牌推广网站
  • 网站必须备案吗如何购买域名
  • 移动app设计网站建设建设公司网站大概需要多少钱?
  • 甜蜜高端定制网站如何做好市场推广
  • 新乡网站关键字优化口碑优化seo
  • 学校 网站源码网站优化排名易下拉软件
  • wordpress插件中文网站优化软件
  • 太原推广团队余姚关键词优化公司
  • 网站如何做301跳转百度网盘网页版登录首页
  • 网站开发设计工程师岗位职责网络营销模式
  • 山东工程网站建设抖音推广运营公司
  • 在南海建设工程交易中心网站网络营销推广的方法有哪些
  • Fastcgi做网站semi final
  • 湘潭网站建设 电话磐石网络线上推广引流渠道
  • wordpress复制文章app优化网站
  • wordpress+怎么改密码忘记郑州seo外包费用
  • 银川注册公司流程和费用优化大师下载安装免费
  • vi设计公司网站香港疫情最新消息
  • 做网站简单还是app简单我想注册一个网站怎么注册
  • asp建设的网站制作上海自动seo
  • 做外贸什么网站比较好做广告联盟下载app
  • 低代码开发技术seo排名分析
  • 做网站第二年要续费吗成都新闻今日最新消息
  • 手机网站模板下载深圳百度推广客服
  • 闲鱼搭建网站网站优化平台