d2025331

目录

一、删除有序数组中的重复项II

二、删除有序数组中的重复项

三、数字转罗马格式

一、删除有序数组中的重复项II

一下写过,挺舒服!

1、统计超出2的数量有多少,仅保留2个重复数字

2、有多少次就从后往前覆盖几次

java 复制代码
  public int removeDuplicates(int[] nums) {
        int i = 0;
        int len = nums.length;
        while(i < len){
            int count = 1;
            while(i+1 < len && nums[i] == nums[i+1]){
                count++;
                i++;
            }
            while(count > 2){
                move(i,nums,len);
                len--;
                i--;
                count--;
            }
            i++;
        }
        return len;
    }
    public void move(int i,int[] nums,int len){
        for(;i < len-1;i++){
            nums[i] = nums[i+1];
        }
    }

二、删除有序数组中的重复项

开始覆盖的时机是当count > 1,仅保留1个重复数字

java 复制代码
  public int removeDuplicates(int[] nums) {
        int i = 0;
        int len = nums.length;
        while(i < len){
            int count = 1;
            while(i+1 < len && nums[i] == nums[i+1]){
                count++;
                i++;
            }
            while(count > 1){
                move(i,nums,len);
                len--;
                i--;
                count--;
            }
            i++;
        }
        return len;
    }
    public void move(int i,int[] nums,int len){
        for(;i < len-1;i++){
            nums[i] = nums[i+1];
        }
    }

三、数字转罗马格式

12. 整数转罗马数字 - 力扣(LeetCode)

难得见题目这么详细的说有哪些情况,然后照着情况来写就行

java 复制代码
public String intToRoman(int num) {
       StringBuilder s = new StringBuilder();
        if (num >= 1000) {
            int mCount = num / 1000;
            num -= (mCount * 1000);
            while (mCount-- > 0) {
                s.append("M");
            }
        }
        if (num / 100 == 9) {
            s.append("CM");
            num -= 900;
        }
        if (num >= 500) {
            int dCount = num / 500;
            num -= (dCount * 500);
            while (dCount-- > 0) {
                s.append("D");
            }
        }
        if (num / 100 == 4) {
            s.append("CD");
            num -= 400;
        }
        if (num >= 100) {
            int cCount = num / 100;
            num -= (cCount * 100);
            while (cCount-- > 0) {
                s.append("C");
            }
        }
        if (num / 10 == 9) {
            s.append("XC");
            num -= 90;
        }
        if (num >= 50) {
            int lCount = num / 50;
            num -= (lCount * 50);
            while (lCount-- > 0) {
                s.append("L");
            }
        }
        if (num / 10 == 4) {
            s.append("XL");
            num -= 40;
        }
        if (num >= 10) {
            int lCount = num / 10;
            num -= (lCount * 10);
            while (lCount-- > 0) {
                s.append("X");
            }
        }
        if (num / 1 == 9) {
            s.append("IX");
            num -= 9;
        }
        if (num >= 5) {
            int lCount = num / 5;
            num -= (lCount * 5);
            while (lCount-- > 0) {
                s.append("V");
            }
        }
        if (num / 1 == 4) {
            s.append("IV");
            num -= 4;
        }
        if (num >= 1) {
            int lCount = num / 1;
            num -= (lCount * 1);
            while (lCount-- > 0) {
                s.append("I");
            }
        }
        return s.toString();
    }
相关推荐
8***29315 分钟前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
CoderYanger8 分钟前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
jllllyuz23 分钟前
Matlab实现基于Matrix Pencil算法实现声源信号角度和时间估计
开发语言·算法·matlab
q***062929 分钟前
Tomcat的升级
java·tomcat
稚辉君.MCA_P8_Java34 分钟前
DeepSeek 插入排序
linux·后端·算法·架构·排序算法
多多*38 分钟前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
青云交40 分钟前
Java 大视界 -- Java 大数据在智能物流无人配送车路径规划与协同调度中的应用
java·spark·路径规划·大数据分析·智能物流·无人配送车·协同调度
d***81721 小时前
解决SpringBoot项目启动错误:找不到或无法加载主类
java·spring boot·后端
ᐇ9591 小时前
Java集合框架深度实战:构建智能教育管理与娱乐系统
java·开发语言·娱乐
.YM.Z2 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法