Merge Two Sorted Lists & Remove Nth Node From End of List
1.合并两个排好序的list
Merge Two Sorted Lists
Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.
2.删除list倒数第n个元素
Remove Nth Node From End of List
Given a linked list, remove the nth node from the end of list and return its head.
For example,
Given linked list: 1->2->3->4->5, and n = 2. After removing the second node from the end, the linked list becomes 1->2->3->5.
Note:
Given n will always be valid.
Try to do this in one pass.
两个问题合在一个工程里面测试
package com.rust.datastruct;
public class MergeTwoSortedLists {
public static ListNode mergeTwoSortedLists(ListNode l1, ListNode l2) {
ListNode r1 = new ListNode(0);
ListNode res = r1;
ListNode t1 = l1;//java 中这样的赋值操作,对了l1操作等同于对t1操作
ListNode t2 = l2;
while (t1 != null && t2 != null){
if (t1.val <= t2.val) {
r1.next = t1;
t1 = t1.next;
} else {
r1.next = t2;
t2 = t2.next;
}
r1 = r1.next;
}
if (t1 != null) {
r1.next = t1;
}
if (t2 != null) {
r1.next = t2;
}
res = res.next;
return res;
}
/**
* @param head
* @param n
* @return ListNode
*/
public static ListNode removeNthFromEnd(ListNode head, int n) {
if (n == 0) return head;
ListNode fakeNode = head;
int count = 0;
while (fakeNode != null) {
fakeNode = fakeNode.next;
count++;
}
fakeNode = head;
if (n == count) {
head = head.next;
return head;
} else {
for (int i = 0; i < count; i++) {
if (i + n + 1== count) {
System.out.println(fakeNode.val);
ListNode cut = fakeNode.next.next;
fakeNode.next = cut;
count--;
continue;
}
fakeNode = fakeNode.next;
}
}
return head;
}
public static void main(String args[]){
ListNode l1 = new ListNode(0);
ListNode l2 = new ListNode(1);
ListNode p1 = l1;
ListNode p2 = l2;
/*initial the list*/
for (int i = 2; i <= 10; i++) {
if (i%2 == 0) {
p1.next = new ListNode(i);
p1 = p1.next;
} else {
p2.next = new ListNode(i);
p2 = p2.next;
}
}
p1 = l1;
p2 = l2;
System.out.println("input List l1 and l2");
showData(l1, l2);//after show,l1 and l2 value didn't change!
System.out.println("mergeTwoLists(l1, l2) -->");
ListNode res = mergeTwoSortedLists(l1, l2);
/** test mergeTwoSortedLists start ************/
while (res.next != null) {// res is destroyed
System.out.print(res.val + "\t");
res = res.next;
}
System.out.println(res.val);
System.out.println("After merge");
/** End ***********************************/
/** test removeNthFromEnd start **************/
showData(l1, l2);
// use l2 to test
int n = 1;
l2 = removeNthFromEnd(l2,n);
showData(l1, l2);
/** End ***********************************/
}
/**
* Print the ListNode
* @param l1 ListNode
* @param l2 ListNode
*/
public static void showData(ListNode l1, ListNode l2){
System.out.println("l1 -->");
while (l1.next != null) {
System.out.print(l1.val + "\t");
l1 = l1.next;
}
System.out.println(l1.val);
System.out.println("l2 -->");
while (l2.next != null) {
System.out.print(l2.val + "\t");
l2 = l2.next;
}
System.out.println(l2.val);
System.out.println("/************************************/");
}
}
//Definition for singly-linked list.
class ListNode {
int val;
ListNode next;
ListNode(int x) { val = x; }
}
输出:
input List l1 and l2
l1 -->
0 2 4 6 8 10
l2 -->
1 3 5 7 9
/************************************/
mergeTwoLists(l1, l2) -->
0 1 2 3 4 5 6 7 8 9 10
After merge
l1 -->
0 1 2 3 4 5 6 7 8 9 10
l2 -->
1 2 3 4 5 6 7 8 9 10
/************************************/
9
l1 -->
0 1 2 3 4 5 6 7 8 9
l2 -->
1 2 3 4 5 6 7 8 9
/************************************/
Merge Two Sorted Lists & Remove Nth Node From End of List的更多相关文章
- [LeetCode] Merge k Sorted Lists 合并k个有序链表
Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 这 ...
- Merge Two Sorted Lists
Merge Two Sorted Lists https://leetcode.com/problems/merge-two-sorted-lists/ Merge two sorted linked ...
- [Leetcode][Python]21: Merge Two Sorted Lists
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 21: Merge Two Sorted Listshttps://oj.le ...
- [Leetcode][Python]23: Merge k Sorted Lists
# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 23: Merge k Sorted Listshttps://oj.leet ...
- LeetCode之“链表”:Merge Two Sorted Lists && Merge k Sorted Lists
1. Merge Two Sorted Lists 题目链接 题目要求: Merge two sorted linked lists and return it as a new list. The ...
- python 中的堆 (heapq 模块)应用:Merge K Sorted Lists
堆是计算机科学中一类特殊的数据结构的统称.堆通常是一个可以被看做一棵树的数组对象.在队列中,调度程序反复提取队列中第一个作业并运行,因为实际情况中某些时间较短的任务将等待很长时间才能结束,或者某些不短 ...
- 蜗牛慢慢爬 LeetCode 23. Merge k Sorted Lists [Difficulty: Hard]
题目 Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity ...
- LeetCode: Merge k Sorted Lists 解题报告
Merge k Sorted Lists Merge k sorted linked lists and return it as one sorted list. Analyze and descr ...
- [Leetcode] Merge k sorted lists 合并k个已排序的链表
Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 思 ...
随机推荐
- GPU编程--宏观理解篇(1)
GPU编程与CPU编程最大的不同可以概括为以下两点: "The same program is executed on many data elements in parallel" ...
- PHP漏洞之session会话劫持
本文主要介绍针对PHP网站Session劫持.session劫持是一种比较复杂的攻击方法.大部分互联网上的电脑多存在被攻击的危险.这是一种劫持tcp协议的方法,所以几乎所有的局域网,都存在被劫持可能. ...
- 产品经理必备工具-Axure(1)
资源下载: Axure的中文官方下载地址:https://www.axure.com.cn/3510/ Axure汉化包:https://www.axure.com.cn/2616/ Axure元件库 ...
- iOS,Android,Jave后台AES加密解密
AES256 在iOS和Android上的相关代码: http://www.tuicool.com/articles/RVFbmmU 里面可以下载相关的代码. 我们遇到的问题是: 把Android的代 ...
- Java IO学习笔记三
Java IO学习笔记三 在整个IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换类. OutputStreamWriter:是Writer的子类,将输出的 ...
- ionic 使用了 crosswalkwebview 所产生的bug 及 解决方案
一.问题产生: 在ionic app 优化方案中,我在前之前的博文中提到使用 --crosswalkwebview: 使用了crosswalkwebview后,app的显示及兼容效果确实很不错,虽然a ...
- CSS3 @keyframes 规则
今天来给大家分享一下CSS3 @keyframes 规则! 在你了解CSS3 @keyframes 规则时我先来给大家说说什么是css3中的动画 动画是使元素从一种样式逐渐变化为另一种样式的效果. 您 ...
- 将angular-ui-bootstrap的弹出框定义成一个服务的实践
定义一个弹出框的服务:alert_boxdefiine(["app"],function(mainapp){ mainapp.controller('ModalInstanceCt ...
- zepto的使用方法
有些不了解zepto的同学在刚接触的时候肯定有很多疑惑,这个东西怎么用啊,去哪里下载啊,什么时候该用什么时候不该用啊,其实我以前也是这样的.jquery使用多了那么就让我们一起来了解下zepto把. ...
- MySQL各模块工作配合
MySQL各模块工作配合 在了解了 MySQL 的各个模块之后,我们再看看 MySQL 各个模块间是如何相互协同工作的 .接下来,我们通过启动 MySQL,客户端连接,请求 query,得到返回结果, ...