Palindrome Linked List

 /**
  * LeetCode: Palindrome Linked List
  * Given a singly linked list, determine if it is a palindrome.
  * Could you do it in O(n) time and O(1) space?
  *
  * @author LuoPeng
  * @time 2015.8.3
  *
  */
 public class Solution {

     /**
      * Reverse the second part, then compare the nodes one by one.
      * Time: O(n) + O((n-1)/2) + O(n/2-1) + O(n/2) + O(1) = O(n)
      * Space: Only 7 parameters are needed, so it is O(1)
      *
      * @param head the first node of a linked list
      * @return true if it is a palindrome, false otherwise.
      */
     public boolean isPalindrome(ListNode head) {

         if ( head == null || head.next == null) {return true;}

         ListNode middle = null; // the middle index of linked list
         ListNode current = null; // the nodes need to be reversed
         ListNode lastHaveReversed = null; // the last node that has been reversed
         ListNode temp = head; 

         /*
          * the size of linked list
          * Time: O(n)
          */
         int length = 0;
         while (temp != null) {
             temp = temp.next;
             length++;
         }

         /*
          * get the index of middle
          * Time: O((n-1)/2)
          */
         int i = 0, size;
         middle = head;
         size = (length-1)/2;
         while ( i < size) {
             middle = middle.next;
             i++;
         }

         /*
          * reverse the last half part, from middleNext to the end
          * just like the insert-sort
          * Time: O(n/2-1)
          */
         size = length/2-1; // the number of nodes need to be reversed
         lastHaveReversed = middle.next;
         current = lastHaveReversed.next;
         for ( i = 0; i < size; i++) {
             lastHaveReversed.next = current.next;
             current.next = middle.next;
             middle.next = current;
             current = lastHaveReversed.next;
         }

         /*
          * judge
          * Time: O(n/2)
          */
         temp = head; // the start of first part
         middle = middle.next; // the start of second part
         for ( i = 0; i < length/2; i++) {
             if ( temp.val == middle.val) {
                 temp = temp.next;
                 middle = middle.next;
             } else {
                 break;
             }
         }

         return i == length/2;

     }

     /**
      * For every node in the first part, find the other one in the second part and compare the value
      * Time: O(n)
      * Space: O(1)
      *
      * @param head
      * @return
      */
     public boolean isPalindrome2(ListNode head) {
         if ( head == null || head.next == null) {
             return true;
         } else {
             ListNode temp = head;
             int length = 0;
             while (temp != null) {
                 temp = temp.next;
                 length++;
             }

             int i, j;
             for ( i = 0; i < length/2; i++) {
                 j = i;
                 temp = head;
                 while (j < length-1-i) {
                     temp = temp.next;
                     j++;
                 }
                 if ( head.val != temp.val) {
                     break;
                 }
                 head = head.next;
             }
             return i == length/2;
         }
     }

 }

Implement Queue using Stacks

 /**
  * LeetCode: Implement Queue using Stacks
  *
  * @author LuoPeng
  * @time 2015.8.3
  *
  */

 class MyQueue {
     // Push element x to the back of queue.
     public void push(int x) {
         main.push(x);
     }

     // Removes the element from in front of queue.
     public void pop() {
         int size = main.size();
         for ( int i = 0; i < size-1; i++ ) {
             help.push(main.peek());
             main.pop();
         }
         main.pop();
         for ( int i = 0; i < size-1; i++) {
             main.push(help.peek());
             help.pop();
         }
     }

     // Get the front element.
     public int peek() {
         int size = main.size();
         for ( int i = 0; i < size-1; i++ ) {
             help.push(main.peek());
             main.pop();
         }
         int value = main.peek();
         for ( int i = 0; i < size-1; i++) {
             main.push(help.peek());
             help.pop();
         }
         return value;
     }

     // Return whether the queue is empty.
     public boolean empty() {
         return main.empty();
     }

     private MyStack main = new MyStack();
     private MyStack help = new MyStack();
 }

 class MyStack {
     public void push(int x) {
         values.add(x);
     }
     public void pop() {
         values.remove(values.size()-1);
     }
     public int peek() {
         return values.get(values.size()-1);
     }
     public boolean empty() {
         return values.size() == 0;
     }
     public int size() {
         return values.size();
     }

     private List<Integer> values = new ArrayList<Integer>();
 }

LeetCode Day1的更多相关文章

  1. 【LeetCode算法题库】Day1:TwoSums & Add Two Numbers & Longest Substring Without Repeating Characters

    [Q1] Given an array of integers, return indices of the two numbers such that they add up to a specif ...

  2. leetcode每日刷题计划-简单篇day1

    orzorz开始刷题 争取坚持每周平均下来简单题一天能做两道题吧 非常简单的题奇奇怪怪的错误orz越不做越菜 Num 7 整数反转 Reverse Integer 刚开始多给了一个变量来回折腾占地方, ...

  3. 刷leetcode是什么样的体验?【转】

    转自:https://www.zhihu.com/question/32322023 刷leetcode是什么样的体验? https://leetcode.com/ 1 条评论   默认排序 按时间排 ...

  4. 知乎上的一些文章---leetcode【笔记1】

    张土汪 http://github.com/shawnfan Java{script}代码仔 42 人赞同 [1.19.2017] 更新: 2017年1月17日, 陪我征战多年的 2014 MackB ...

  5. 【Leetcode周赛】从contest-51开始。(一般是10个contest写一篇文章)

    Contest 51 (2018年11月22日,周四早上)(题号681-684) 链接:https://leetcode.com/contest/leetcode-weekly-contest-51 ...

  6. 我为什么要写LeetCode的博客?

    # 增强学习成果 有一个研究成果,在学习中传授他人知识和讨论是最高效的做法,而看书则是最低效的做法(具体研究成果没找到地址).我写LeetCode博客主要目的是增强学习成果.当然,我也想出名,然而不知 ...

  7. LeetCode All in One 题目讲解汇总(持续更新中...)

    终于将LeetCode的免费题刷完了,真是漫长的第一遍啊,估计很多题都忘的差不多了,这次开个题目汇总贴,并附上每道题目的解题连接,方便之后查阅吧~ 477 Total Hamming Distance ...

  8. [LeetCode] Longest Substring with At Least K Repeating Characters 至少有K个重复字符的最长子字符串

    Find the length of the longest substring T of a given string (consists of lowercase letters only) su ...

  9. Leetcode 笔记 113 - Path Sum II

    题目链接:Path Sum II | LeetCode OJ Given a binary tree and a sum, find all root-to-leaf paths where each ...

随机推荐

  1. Android应用程序窗口(Activity)实现框架简要介绍和学习计划

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8170307 前面我们学习了SurfaceFli ...

  2. 让man 显示中文

    1.添加库函数手册 ubuntu默认是没有安装c语言的库函数man手册的,所以你在man perror 和sendto之类的函数时会显示没有相关文档的问题,这个问题让我郁闷了我好久.解决方法: sud ...

  3. .net 时间操作[摘抄]

    .Net时间运算 - DateTime类,TimeSpan类http://www.cnblogs.com/kissdodog/archive/2013/03/02/2939927.html 时间戳转换 ...

  4. .NET 下成熟开源的BPM产品四款推荐

    .net下的BPM产品相比JAVA的确实不多,这里主要提4款. 1.博客园.github.codeplex上的开源的流程组件AppInOne BPM,目前已有不少的企业开始使用. 优点:产品框架较全面 ...

  5. (转)Java字符串应用之密码加密与验证

    1.通过java.Security.MessageDigest的静态方法getInstance创建具有指定算法名称的信息摘要,参数为算法名,传入”MD5“则表示使用MD5算法    2.Message ...

  6. Mac系统杂项 (持续更新)

    一.调整LaunchPad的图标显示列数和行数 .调整每一列显示图标数量.在我的电脑上(1366 * 768),每列7个个人觉得比较不错 defaults write com.apple.dock s ...

  7. CDZSC_2015寒假新人(1)——基础 a

    Description Contest time again! How excited it is to see balloons floating around. But to tell you a ...

  8. XML新手入门 创建构造良好的XML(2)

    本文描述了构建良好的XML需要遵循的规则.作者详细介绍了构建XML需要考虑的元素,如何命名约定.正确的标记嵌套.属性规则.声明和实体,以及DTD和schema的验证,十分便于新手开始学习了解XML. ...

  9. 基于DateTime Picker修改成类似旅游网站出发日期选择的功能

    原版说明文档:http://www.bootcss.com/p/bootstrap-datetimepicker/ 修改后可支持多日期选择和控制可选日期,这样就能在后台设置哪些日期可选,前台展示时可以 ...

  10. WinCe 如何使应用程序只开启一个

    方法一: namespace MyNameSpace{ static class Program { [DllImport("Toolhelp.dll")] public stat ...