Leetcode刷题 2021.01.16

Leetcode1721 交换链表中的节点

给你链表的头节点 head 和一个整数 k 。

交换 链表正数第 k 个节点和倒数第 k 个节点的值后,返回链表的头节点(链表 从 1 开始索引)。

今天一天都在论文预答辩,实在没什么时间刷题了。随便找了两道水题做了,明天再说吧。今天的每日一题也好难,就算知道并查集也做不出来。面试选手就直接CV了。
链表题还是一样的问题,考虑边界,一些特殊情况。代码可能写复杂了,主要是面向测试用例编程,看看什么时候有空优化下吧。

class Solution {
    public ListNode swapNodes(ListNode head, int k) {
        ListNode dummyHead = new ListNode(0);
        //伪头结点
        dummyHead.next = head;
        ListNode cur = dummyHead, prev1 = dummyHead, prev2 = dummyHead;
		//先找第k个,和它前一个指针
        for(int i = 0; i <	 k; i++){
            prev1 = cur;
            cur = cur.next;
        }
        ListNode index1 = cur;
        ListNode cur2 = dummyHead;
        //找倒数第k个,和它前一个指针
        while (cur != null){
            prev2 = cur2;
            cur = cur.next;
            cur2 = cur2.next;
        }
        ListNode index2 = cur2;

        ListNode next = index2.next;
		
		//这里两个特殊情况,面向测试用例编程了。。
        if (index1 == prev2){
            prev1.next = index2;
            index2.next = index1;
            index1.next = next;
            return dummyHead.next;
        }

        if (index2 == prev1){
            ListNode next_1 = index1.next;
            prev2.next = index1;
            index1.next = index2;
            index2.next = next_1;
            return dummyHead.next;
        }
		//正常情况交换下就行了
        prev1.next = index2;
        index2.next = index1.next;
        index1.next = next;
        prev2.next = index1;    

        return dummyHead.next;

    }
}

Leetcode1451 重新排列句子中的单词

「句子」是一个用空格分隔单词的字符串。给你一个满足下述格式的句子 text :

句子的首字母大写
text 中的每个单词都用单个空格分隔。
请你重新排列 text 中的单词,使所有单词按其长度的升序排列。如果两个单词的长度相同,则保留其在原句子中的相对顺序。

请同样按上述格式返回新的句子。

还是比较简单的,排序再加上简单操作而已。一开始写的有点复杂,参考了评论的代码,修改了下。太简单了,也没什么好注释的了。今天好水,明天加油吧。

class Solution {
    public String arrangeWords(String text) {
        String[] arr = text.toLowerCase().split(" ");
        Arrays.sort(arr, (x, y) -> (x.length() - y.length()));

        char first = arr[0].charAt(0);
        first = Character.toUpperCase(first);
        arr[0] = first + arr[0].substring(1);

        return String.join(" ", arr);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值