[算法很美打卡第四天] 字符串篇(中)

这篇具有很好参考价值的文章主要介绍了[算法很美打卡第四天] 字符串篇(中)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

压缩字符串

[算法很美打卡第四天] 字符串篇(中),暑期算法冲刺,算法,java,数据结构,原力计划

代码

package 每日算法学习打卡.算法打卡.八月份;

public class test1 {
    public static void main(String[] args) {
        String s = "avss";
        System.out.println(zipString(s));
    }

    public static String zipString(String src) {
        StringBuilder sb = new StringBuilder(); // 用来拼接形成新字符串
        char temp = 0; // 上一个字符
        int count = 0; // 计数,字符出现了几次

        for (int i = 0; i < src.length(); i++) {
            char charAt = src.charAt(i); // 当前字符
            if (sb.length() == 0) { // 处理第一个字符
                sb.append(charAt);
                temp = charAt;
                count = 1;
            } else { // 处理除第一个字符外其他字符
                if (temp == charAt) {
                    count++; // 当前字符与temp相同,计数+1
                } else { // 当前字符与temp不同
                    sb.append(count).append(charAt); // 将前一个不同字符的数量、新一个字符加入sb
                    temp = charAt; // 更新temp为当前字符
                    count = 1; // 更新计数值为1
                }
            }
        }

        // 循环结束后最后一个字符的情况可能没有记录下去
        if (count >= 1)
            sb.append(count);

        // 比较新字符串和原字符串
        if (sb.length() >= src.length())
            return src;

        return sb.toString();
    }
}

判断两字符串的字符集是否相同

代码

使用Unicode256编码集解决

package 每日算法学习打卡.算法打卡.八月份;

public class test2 {
    //使用ACII编码进行核对
    public static void main(String[] args) {
        String s1 = "aaa";
        String s2 = "aac";
        System.out.println(check(s1,s2));
    }

    public static boolean check(String s1, String s2) {
        int[] help = new int[256];
        for (int i = 0; i < s1.length(); i++) {
            char c = s1.charAt(i);
            if (help[c] == 0) {
                help[c] = 1;
            }
        }
        for (int i = 0; i < s2.length(); i++) {
            char c = s2.charAt(i);
            if (help[c] == 0) {
                return false;
            }
        }
        return true;

    }
}

使用hashmap解决:

package 每日算法学习打卡.算法打卡.八月份;

import java.util.HashMap;
import java.util.Map;

public class test3 {
    public static void main(String[] args) {
        String s1 = "aaa";
        String s2 = "aac";
        System.out.println(hashCheck(s1,s2));
    }
    public static boolean hashCheck(String s1,String s2){
        Map<Character,Integer> map = new HashMap<Character,Integer>();
        for(int i =0;i<s1.length();i++){
            char c = s1.charAt(i);
            if(map.get(c) == null){
                map.put(c,1);
            }
        }
        for(int i =0;i<s2.length();i++){
            char c = s2.charAt(i);
            if(map.get(c) == null){
                return false;
            }
        }
        return true;
    }

}

旋转词

[算法很美打卡第四天] 字符串篇(中),暑期算法冲刺,算法,java,数据结构,原力计划

代码

package 每日算法学习打卡.算法打卡.八月份;

public class test4 {
    public static void main(String[] args) {
        String s1 = "aaass";
        String s2 = "aassa";
        System.out.println(reverseString(s1,s2));
    }
    //旋转词
    public static boolean reverseString(String s1,String s2){
        StringBuilder sb = new StringBuilder(s1).append(s1);
        return sb.toString().contains(s2);
    }
}

反转单词

代码

package 每日算法学习打卡.算法打卡.八月份;

public class test5 {
    //将字符串中安单词翻转
    public static void main(String[] args) {
        String s = reverse("here are you");
        System.out.println(s);
    }
    public static String reverse(String src){
        String[] help = src.split("\\s");
        StringBuilder sb = new StringBuilder();
        for(int i = help.length-1;i>=0;i--){
            sb.append(help[i] +" ");
        }
        return sb.deleteCharAt(sb.length()-1).toString();
    }
}

回文串验证

代码

package 每日算法学习打卡.算法打卡.八月份;

public class test8 {
    public static void main(String[] args) {
    
    }
    public static boolean isPalindrome(String src){
        if(src.isEmpty()){
            return true;
        }
        return src.equals(new StringBuilder(src).reverse().toString());
    }
    
}

去掉字符串中连接出现的k次的0

代码

package 每日算法学习打卡.算法打卡.八月份;

public class test7 {
    public static void main(String[] args) {
        String s = "aaa00aaa";
        System.out.println(remove2(s,2));
    }
    // 常规做法
    public static String remove2(String s, int k) {
        char[] arr = s.toCharArray(); // 转为字符型数组
        int cnt = 0; // 计数
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < arr.length; i++) {
            char c = arr[i];
            if (c == '0') // 若发现0,进行计数
                cnt++;
            else { // 若不是0,加入sb
                for (int j = 0; j < cnt % k; j++) { // 将超过k个的0超出部分加入sb
                    sb.append('0');
                }
                sb.append(c); // 不是0的字符直接加入
                cnt = 0; // 重置计数器
            }
        }

        // 字符串末尾可能存在0,跳出上一个循环后只进行了计数,没有判断是否需要加入sb
        // 在此补充操作
        for (int i = 0; i < cnt % k; i++) {
            sb.append('0');
        }

        return sb.toString();
    }

}

正则表达式:文章来源地址https://www.toymoban.com/news/detail-647398.html

package 每日算法学习打卡.算法打卡.八月份;

public class test6 {
    public static void main(String[] args) {
        String s = "aaa00aaa";
        System.out.println(remove(s,2));
    }
    public static String remove(String s,int n){
        String regexp = "0{"+n+"}";
        return s.replaceAll(regexp,"");
    }
}

到了这里,关于[算法很美打卡第四天] 字符串篇(中)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

原文地址:https://blog.csdn.net/weixin_54174102/article/details/132050114

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包