剑指offer:18-21记录

举报
兔老大 发表于 2021/04/22 23:31:22 2021/04/22
【摘要】 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。 返回删除后的链表的头节点。 注意:此题对比原题有改动 示例 1: 输入: head = [4,5,1,9], val = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9. 示例 2...

给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。

返回删除后的链表的头节点。

注意:此题对比原题有改动

示例 1:

输入: head = [4,5,1,9], val = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
示例 2:

输入: head = [4,5,1,9], val = 1
输出: [4,5,9]
解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9.
 

说明:

题目保证链表中节点的值互不相同
若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除的节点

思路:注意头结点即可,制造一个假节点解决问题是常用方法。


  
  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 ListNode deleteNode(ListNode head, int val) {
  11. ListNode temp=new ListNode(-1);
  12. temp.next=head;
  13. for(ListNode i=temp;i.next!=null;i=i.next){
  14. if(i.next.val==val){
  15. i.next=i.next.next;
  16. break;
  17. }
  18. }
  19. return temp.next;
  20. }
  21. }

请实现一个函数用来匹配包含'. '和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(含0次)。在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但与"aa.a"和"ab*a"均不匹配。

示例 1:

输入:
s = "aa"
p = "a"
输出: false
解释: "a" 无法匹配 "aa" 整个字符串。
示例 2:

输入:
s = "aa"
p = "a*"
输出: true
解释: 因为 '*' 代表可以匹配零个或多个前面的那一个元素, 在这里前面的元素就是 'a'。因此,字符串 "aa" 可被视为 'a' 重复了一次。
示例 3:

输入:
s = "ab"
p = ".*"
输出: true
解释: ".*" 表示可匹配零个或多个('*')任意字符('.')。
示例 4:

输入:
s = "aab"
p = "c*a*b"
输出: true
解释: 因为 '*' 表示零个或多个,这里 'c' 为 0 个, 'a' 被重复一次。因此可以匹配字符串 "aab"。
示例 5:

输入:
s = "mississippi"
p = "mis*is*p*."
输出: false
s 可能为空,且只包含从 a-z 的小写字母。
p 可能为空,且只包含从 a-z 的小写字母,以及字符 . 和 *。

思路:字符串dp,注意仔细读题。


  
  1. class Solution {
  2. public boolean isMatch(String s,String p){
  3. if (s == null || p == null)return false;
  4. int sLen=s.length();
  5. int pLen=p.length();
  6. boolean[][] dp = new boolean[sLen + 1][pLen + 1];
  7. dp[0][0] = true;//dp[i][j] 表示 s 的前 i 个是否能被 p 的前 j 个匹配
  8. for (int i = 0; i < pLen; i++) { // here's the p's length, not s's
  9. dp[0][i + 1] = p.charAt(i) == '*' && dp[0][i - 1];
  10. }
  11. for (int i = 0; i < sLen; i++) {
  12. for (int j = 0; j < pLen; j++) {
  13. //单个字符可以匹配
  14. if (p.charAt(j) == '.' || p.charAt(j) == s.charAt(i)) dp[i + 1][j + 1] = dp[i][j];
  15. //多个字符
  16. if (p.charAt(j) == '*') {
  17. dp[i+1][j+1]=dp[i+1][j-1] ||
  18. (dp[i+1][j] && (s.charAt(i)==p.charAt(j-1) || p.charAt(j-1)=='.')) ||
  19. (dp[i][j+1] && (s.charAt(i)==p.charAt(j-1) || p.charAt(j-1)=='.'));
  20. }
  21. }
  22. }
  23. return dp[sLen][pLen];
  24. }
  25. }

请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100"、"5e2"、"-123"、"3.1416"、"0123"及"-1E-16"都表示数值,但"12e"、"1a3.14"、"1.2.3"、"+-5"及"12e+5.4"都不是。

思路1:try catch


  
  1. class Solution {
  2. public boolean isNumber(String s) {
  3. try {
  4. if (s.endsWith("f") || s.endsWith("F")
  5. || s.endsWith("D") || s.endsWith("d")) {
  6. return false;
  7. }
  8. Double.valueOf(s);
  9. return true;
  10. } catch (Exception exception) {
  11. return false;
  12. }
  13. }
  14. }

思路2:正则


  
  1. class Solution:
  2. def isNumber(self, s: str) -> bool:
  3. return bool(re.match(r' *[+-]?([0-9]+(\.[0-9]*)?|\.[0-9]+)(e[+-]?[0-9]+)? *$', s))

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。

 

示例:

输入:nums = [1,2,3,4]
输出:[1,3,2,4] 
注:[3,1,2,4] 也是正确的答案之一。
 

提示:

1 <= nums.length <= 50000
1 <= nums[i] <= 10000

思路:和快排一趟partation类似


  
  1. class Solution {
  2. public int[] exchange(int[] nums) {
  3. int i = 0, j = nums.length - 1, tmp;
  4. while(i < j) {
  5. while(i < j && (nums[i] & 1) == 1) i++;
  6. while(i < j && (nums[j] & 1) == 0) j--;
  7. tmp = nums[i];
  8. nums[i] = nums[j];
  9. nums[j] = tmp;
  10. }
  11. return nums;
  12. }
  13. }

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/104757554

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。