[Java 算法] 字符串

练习一 : 最长公共前缀

14. 最长公共前缀 - 力扣(LeetCode)

方法一 :

java 复制代码
class Solution {
    public String longestCommonPrefix(String[] strs) {
        int n = strs.length;
        String ret = strs[0];
        for(int i = 1;i<n;i++){
            ret = findComment(strs[i],ret);
        }
        return ret;
    }
    public String findComment(String str1,String str2){
        int i = 0;
        while(i<Math.min(str1.length(),str2.length())&&str1.charAt(i) == str2.charAt(i)) i++;
        return str1.substring(0,i);
    }
}

字符串数组看作一条链,依次两两比较,不断缩小公共前缀的范围

方法二 :

java 复制代码
class Solution {
    public String longestCommonPrefix(String[] strs) {
        int n = strs.length;
        String tmp = strs[0];
        for(int i = 0;i<tmp.length();i++){
            char s = tmp.charAt(i);
            for(int j = 1;j<strs.length;j++){
                if(i == strs[j].length()||(strs[j].charAt(i)!=s)){
                    return tmp.substring(0,i);
                }
            }
        }
        return tmp;
    }
}

以第一个字符串为基准,逐字符地去对比其他所有字符串。

练习二 : 最长回文子串

5. 最长回文子串 - 力扣(LeetCode)

java 复制代码
class Solution {
    public String longestPalindrome(String s) {
        int begin = 0,len = 0;
        int n = s.length();
        for(int i = 0;i<n;i++){
            //先扩展奇数长度
            int left = i,right = i;
            while(left>=0&&right<n&&s.charAt(left) == s.charAt(right)){
                left--;
                right++;
            }
            if(right-left-1>len){
                begin = left+1;
                len = right- left-1;
            }

            //扩展偶数长度
            left = i;
            right = i+1;
            while(left>=0&&right<n&&s.charAt(left) == s.charAt(right)){
                left--;
                right++;
            }
            if(right-left-1>len){
                begin = left+1;
                len = right-left-1;
            }
        }
        return s.substring(begin,begin+len);
    }
}

中心扩展算法 , 分别枚举奇数长度以 i 为中心的子串 , 和偶数长度以 i 为中心的子串

练习三 : 二进制求和

67. 二进制求和 - 力扣(LeetCode)

java 复制代码
class Solution {
    public String addBinary(String a, String b) {
        int cur1 = a.length()-1,cur2 = b.length()-1,t = 0;
        StringBuffer s = new StringBuffer();
        while(cur1>=0||cur2>=0||t>0){
            if(cur1>=0) t+=a.charAt(cur1--)-'0';
            if(cur2>=0) t+=b.charAt(cur2--)-'0';
            s.append(""+t%2);
            t/=2;
        }
        s.reverse();
        return s.toString();
    }
}

模拟加法列竖式运算

相加 : 前一位的进位 t+=两数的当前位 , 满 2 进 1 : t%2

进位 : t/=2

从最低位开始拼字符串 , 最低位在字符串的起始位置 , 最终得到的数是逆序的

练习四 : 字符串相乘

43. 字符串相乘 - 力扣(LeetCode)

java 复制代码
class Solution {
    public String multiply(String num1, String num2) {
        num1 = new StringBuilder(num1).reverse().toString();
        num2 = new StringBuilder(num2).reverse().toString();
        int n1 = num1.length(),n2 = num2.length();
        int[]tmp = new int[n1+n2-1];
        for(int i = 0;i<n1;i++){
            for(int j = 0;j<n2;j++){
                int a = num1.charAt(i)-'0';
                int b = num2.charAt(j)-'0';
                tmp[i+j]+=a*b;
            }
        }
        StringBuffer ret = new StringBuffer();
        int index = 0,t = 0;
        while(index<tmp.length||t!=0){
            if(index<tmp.length) t+=tmp[index++];
            ret.append(t%10+"");
            t/=10;
        }
        ret.reverse();
        // 处理前导 0
        while (ret.length() > 1 && ret.charAt(0) == '0') {
            ret.deleteCharAt(0);
        }
        return ret.toString();
    }
}

1.字符串逆转

2.将两个字符串 第 i 位 × 第 j 位 存放在 tmp[] 的 i+j 位 ; 只累加不进位

3.模拟字符串相加

相关推荐
故事和你912 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
m0_694845572 小时前
Dify部署教程:从AI原型到生产系统的一站式方案
服务器·人工智能·python·数据分析·开源
Fcy6482 小时前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy2 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
菱玖3 小时前
SRC常见漏洞情况分类
运维·安全·安全威胁分析
码云数智-大飞3 小时前
C++ RAII机制:资源管理的“自动化”哲学
java·服务器·php
List<String> error_P3 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
SkyXZ~3 小时前
Jetson有Jtop,Linux有Htop,RDK也有Dtop!
linux·运维·服务器·rdkx5·rdks100·dtop
迈巴赫车主4 小时前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯