A.每日一题——3606. 优惠券校验器

题目链接:3606. 优惠券校验器(简单)

算法原理:

解法:模拟

击败47.54%

时间复杂度O(Nlogn)

这题的思路非常简单,但是实现起来比较麻烦,感觉应该算个中等题,主要就是考察排序

记忆👇

  1. 字符串比:compareTo ✅

什么词序、字典序、名称排序都用它

  1. 数字比:用包装类的 compare ✅

Integer.compare(a, b)、Double.compare(a, b)

  1. 其他基本类型:直接相减 ✅

char1 - char2、int1 - int2(小数值可用)

Java代码:

java 复制代码
class Solution {
    public List<String> validateCoupons(String[] c, String[] b, boolean[] isActive) {
        int n=c.length;
        List<String> ret=new ArrayList<>();
        String[][] tmp=new String[n][2];
        for(int i=0;i<n;i++){
            if(isc(c[i])&&isb(b[i])&&isActive[i]){
                tmp[i][0]=c[i];
                tmp[i][1]=b[i];
            }else{
                //标记为无效记录,防止空指针报错
                tmp[i][0]="";
                tmp[i][1]="";
            }
        }
        Arrays.sort(tmp,(x,y)->{
            //处理空记录:空记录排在最后
            if(x[0].equals("")&&y[0].equals("")) return 0;
            if(x[0].equals("")) return 1;//x为空,x在后面
            if(y[0].equals("")) return -1;//y为空,x在前面
            //先比较品牌首字符
            int tmpret=Character.compare(x[1].charAt(0),y[1].charAt(0));
            if(tmpret!=0) return tmpret;
            //品牌首字母相同,再比较代码
            return x[0].compareTo(y[0]);
        });
        for(String[] t:tmp){
            if(t[0].equals("")) continue;
            ret.add(t[0]);
        }
        return ret;
    }
    private boolean isc(String s){
        for(char c:s.toCharArray()){
            if(!(c>='a'&&c<='z')&&!(c>='A'&&c<='Z')
                &&!(c>='0'&&c<='9')&&!(c=='_')) 
            return false;
        }
        return true;
    }
    private boolean isb(String s){
        return (s.equals("electronics")||s.equals("grocery")||s.equals("pharmacy")||s.equals("restaurant"));
    }
}
相关推荐
Lancer-3119 小时前
打开JAVA控制台(Java control panel )
java·开发语言
Hcoco_me19 小时前
大模型面试题46:在训练7B LLM时,如果使用AdamW优化器,那么它需要的峰值显存是多少?
开发语言·人工智能·深度学习·transformer·word2vec
一个不知名程序员www19 小时前
算法学习入门--- set与map(C++)
c++·算法
技术小泽19 小时前
MQTT从入门到实战
java·后端·kafka·消息队列·嵌入式
POLITE319 小时前
Leetcode 142.环形链表 II JavaScript (Day 10)
javascript·leetcode·链表
福大大架构师每日一题19 小时前
milvus v2.6.8 发布:搜索高亮上线,性能与稳定性全面跃升,生产环境强烈推荐升级
android·java·milvus
键盘林19 小时前
java: 找不到符号
java
鸿途优学-UU教育19 小时前
法考命题趋势解读:为何越来越重视“实战能力”?
算法·法律·uu教育·法考机构
Rui_Freely19 小时前
Vins-Fusion之 相机—IMU在线标定(两帧间旋转估计)(十)
人工智能·算法·计算机视觉
独自破碎E19 小时前
链表中的节点每k个一组翻转
数据结构·链表