返回倒数第 k 个节点

实现一种算法,找出单向链表中倒数第 k 个节点。返回该节点的值。
注意:本题相对原题稍作改动

示例:
输入: 1->2->3->4->5 和 k = 2
输出: 4
说明:
给定的 k 保证是有效的。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/kth-node-from-end-of-list-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

重点总结

  1. 明晰链表的创建方法
  2. 双指针法

    1. 栈(待补充)

    2. 递归(待补充)

    1. /**
    2. * Definition for singly-linked list.
    3. * public class ListNode {
    4. * int val;
    5. * ListNode next;
    6. * ListNode(int x) { val = x; }
    7. * }
    8. */
    9. class Solution {
    10. public int kthToLast(ListNode head, int k) {
    11. ListNode first = head;
    12. ListNode second = head;
    13. //first指针向后走k步
    14. for(int i = 0;i<k;i++){
    15. first = first.next;
    16. }
    17. //first和second指针再同时向后
    18. while(first!=null){
    19. first = first.next;
    20. second = second.next;
    21. }
    22. return second.val;
    23. }
    24. }

删除中间节点

实现一种算法,删除单向链表中间的某个节点(即不是第一个或最后一个节点),假定你只能访问该节点。
示例:
输入:单向链表a->b->c->d->e->f中的节点c
结果:不返回任何数据,但该链表变为a->b->d->e->f

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-middle-node-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

重点总结

  1. 难点在于理解题意。
  2. 删除节点的方式:变成next,删除真正的next。

image.png

  1. /**
  2. * Definition for singly-linked list.
  3. * public class ListNode {
  4. * int val;
  5. * ListNode next;
  6. * ListNode(int x) { val = x; }
  7. * }
  8. */
  9. class Solution {
  10. public void deleteNode(ListNode node) {
  11. //将节点node赋值为其next的值
  12. node.val = node.next.val;
  13. //删除将节点node的下一跳指向next的next,变相的删除了next
  14. node.next = node.next.next;
  15. }
  16. }

上升下降字符串

给你一个字符串 s ,请你根据下面的算法重新构造字符串:

从 s 中选出 最小 的字符,将它 接在 结果字符串的后面。
从 s 剩余字符中选出 最小 的字符,且该字符比上一个添加的字符大,将它 接在 结果字符串后面。
重复步骤 2 ,直到你没法从 s 中选择字符。
从 s 中选出 最大 的字符,将它 接在 结果字符串的后面。
从 s 剩余字符中选出 最大 的字符,且该字符比上一个添加的字符小,将它 接在 结果字符串后面。
重复步骤 5 ,直到你没法从 s 中选择字符。
重复步骤 1 到 6 ,直到 s 中所有字符都已经被选过。
在任何一步中,如果最小或者最大字符不止一个 ,你可以选择其中任意一个,并将其添加到结果字符串。

请你返回将 s 中字符重新排序后的 结果字符串 。

示例 1:
输入:s = “aaaabbbbcccc”
输出:”abccbaabccba”
解释:第一轮的步骤 1,2,3 后,结果字符串为 result = “abc”
第一轮的步骤 4,5,6 后,结果字符串为 result = “abccba”
第一轮结束,现在 s = “aabbcc” ,我们再次回到步骤 1
第二轮的步骤 1,2,3 后,结果字符串为 result = “abccbaabc”
第二轮的步骤 4,5,6 后,结果字符串为 result = “abccbaabccba”

示例 2:
输入:s = “rat”
输出:”art”
解释:单词 “rat” 在上述算法重排序以后变成 “art”

示例 3:
输入:s = “leetcode”
输出:”cdelotee”

示例 4:
输入:s = “ggggggg”
输出:”ggggggg”

示例 5:
输入:s = “spo”
输出:”ops”

提示:
1 <= s.length <= 500
s 只包含小写英文字母。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/increasing-decreasing-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

重点总结

1、理解题意,题目看起来有点不知所云的感觉

2、桶计数的方法

我们可以直接创建一个大小为 26 的桶,记录每种字符的数量。每次提取最长的上升或下降字符串时,我们直接顺序或逆序遍历这个桶。相当于创建的数组就是一个桶对象。

  1. class Solution {
  2. public String sortString(String s) {
  3. int[] num = new int[26];
  4. for (int i = 0; i < s.length(); i++) {
  5. num[s.charAt(i) - 'a']++;
  6. }
  7. StringBuffer ret = new StringBuffer();
  8. while (ret.length() < s.length()) {
  9. for (int i = 0; i < 26; i++) {
  10. if (num[i] > 0) {
  11. ret.append((char) (i + 'a'));
  12. num[i]--;
  13. }
  14. }
  15. for (int i = 25; i >= 0; i--) {
  16. if (num[i] > 0) {
  17. ret.append((char) (i + 'a'));
  18. num[i]--;
  19. }
  20. }
  21. }
  22. return ret.toString();
  23. }
  24. }