算法题目---模拟

(一).算法介绍

"模拟"算法,只需要 "比着葫芦画瓢"即可

"模拟"算法的特点就是思路比较简单,主要是考察代码能力

在做"模拟"算法题的时候,一定要知道算法流程,然后把流程转化成代码

(二).具体题目

1.替换所有的问号

https://leetcode.cn/problems/replace-all-s-to-avoid-consecutive-repeating-characters/

解法:模拟

java 复制代码
    public String modifyString(String s) {
        char[] chars = s.toCharArray();
        for (int i = 0; i < chars.length; i++) {
            if (chars[i]=='?'){
                for (char sh ='a';sh<='z';sh++) {
                    if ((i==0||chars[i-1]!=sh)&&(i==chars.length-1||chars[i+1]!=sh)){
                        chars[i]=sh;
                        break;
                    }
                }
            }
        }
        return String.valueOf(chars);
    }

2.提莫攻击

495. 提莫攻击 - 力扣(LeetCode)

解法:模拟

java 复制代码
    public int findPoisonedDuration(int[] timeSeries, int duration) {
        int ret=0;
        for (int i = 0; i < timeSeries.length-1; i++) {
            int sum=timeSeries[i+1]-timeSeries[i];
            if (sum>=duration){
                ret+=duration;
            }else{
                ret+=sum;
            }
        }
        return ret+duration;
    }

3.Z字型变换

6. Z 字形变换 - 力扣(LeetCode)

解法:模拟

java 复制代码
    public String convert(String s, int numRows) {
        //处理特殊情况,如果numRows=1,那么d=0,所以在处理第一行的时候就会陷入死循环
        if (numRows==1){
            return s;
        }
        StringBuilder stringBuilder=new StringBuilder();
        int d=2*numRows-2; //计算公差
        //处理第一行
        for (int i = 0; i < s.length(); i+=d) {
            stringBuilder.append(s.charAt(i));
        }

        //处理中间行
        for (int i = 1; i < numRows-1; i++) {
            for (int j = i,k=d-i; j <s.length()||k<s.length() ; j+=d,k+=d) {
                if (j<s.length()){
                    stringBuilder.append(s.charAt(j));
                }
                if (k<s.length()){
                    stringBuilder.append(s.charAt(k));
                }
            }
        }
        //处理最后一行
        for (int i = numRows-1; i < s.length(); i+=d) {
            stringBuilder.append(s.charAt(i));
        }

        return stringBuilder.toString();
    }

4.外观数列

38. 外观数列 - 力扣(LeetCode)

解法:模拟

java 复制代码
    public String countAndSay(int n) {
        String ret="1";
        for (int i = 1; i <n ; i++) {
            StringBuilder stringBuilder=new StringBuilder();
            int left=0;
            int right=0;
            while (right<ret.length()){
                while (right<ret.length()&&ret.charAt(left)==ret.charAt(right)){
                    right++;
                }
                stringBuilder.append(String.valueOf(right-left));
                stringBuilder.append(ret.charAt(left));
                left=right;
            }

            ret=stringBuilder.toString();
        }
        return ret;
    }

5.数青蛙

1419. 数青蛙 - 力扣(LeetCode)

解法:模拟

java 复制代码
    public int minNumberOfFrogs(String croakOfFrogs) {
        char[] chars = croakOfFrogs.toCharArray();
        String str="croak";
        int len=str.length();
        // 核心数组:hash[0]~hash[4] 分别记录 叫c、r、o、a、k 的青蛙数量
        int[] hash=new int[len];
        // 哈希表:建立 字符 → 对应下标 的映射(c=0, r=1, o=2, a=3, k=4)
        HashMap<Character,Integer> hashMap=new HashMap<>(); //[str中的字符,字符的下标]
        for (int i = 0; i < len; i++) {
            hashMap.put(str.charAt(i),i);
        }
        for (char ch:chars) {
            if (ch=='c'){ //判断是否为'c'的情况
                if (hash[len-1]!=0){
                    hash[len-1]--;
                }
                hash[0]++;
            }else{
                int index=hashMap.get(ch);
                if (hash[index-1]==0){
                    return -1;
                }
                hash[index-1]--;
                hash[index]++;
            }
        }
        // 遍历结束后检查:c/r/o/a 阶段必须没有青蛙(所有青蛙都叫完了k)
        for (int i = 0; i < len-1; i++) {
            if (hash[i]!=0){
                return -1;
            }
        }
        return hash[len-1];
    }
相关推荐
indexsunny6 小时前
互联网大厂Java面试实战:Spring Boot微服务与Kafka消息队列深度解析
java·spring boot·微服务·面试·kafka·消息队列·电商
『昊纸』℃6 小时前
C语言学习心得集合 篇1
c语言·算法·编程基础·学习心得·实践操作
Chase_______6 小时前
LeetCode 1456:定长子串中元音的最大数目
算法·leetcode
小O的算法实验室6 小时前
2026年IEEE IOTJ,DNA序列启发相似性驱动粒子群算法+无人机与基站部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
谭欣辰6 小时前
Floyd算法:动态规划解最短路径
c++·算法·图论
杨凯凡6 小时前
【019】IO/NIO 概念:Web 开发要掌握到什么程度
java·开发语言·nio
计算机安禾6 小时前
【Linux从入门到精通】第12篇:进程的前后台切换与信号控制
linux·运维·算法
Nicander6 小时前
JDBC PreparedStatement的作用机制
java
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 84. 柱状图中最大的矩形 | C++ 两次单调栈基础扫法
c++·算法·leetcode
MegaDataFlowers6 小时前
解决idea报错不支持发行版本21
java·ide·intellij-idea