三、行相等的最少多米诺旋转(Weekly Contest 127)

本文通过对比两种不同的代码实现方式,展示了如何优化算法并简化代码。通过对原始冗余代码的分析,提出了一种更为简洁高效的算法实现,旨在帮助读者理解算法优化的重要性及其实现方法。

题目描述:
在这里插入图片描述
在这里插入图片描述
当时因为竞赛没有太多考虑,直接用最笨的方法来写的,代码比较冗余

class Solution {
    public int minDominoRotations(int[] A, int[] B) {
        //如果A里面的都相等,直接返回0
		 int first = A[0];
		 boolean iseq = true;
		 for (int i : A) {
			if(i != first){
				iseq = false;
				break;
			}
		}
		 if(iseq){
			 return 0;
		 }
		 //要想找到最小的那么首先需要找到出现次数最多的数字
		 Map<Integer, Integer> map = new TreeMap<>();
		 for (int i : A) {
			map.put(i, map.getOrDefault(i, 0) + 1);
		}
	  
		 
		//这里将map.entrySet()转换成list
	        List<Map.Entry<Integer ,Integer>> list = new ArrayList<Map.Entry<Integer,Integer>>(map.entrySet());
	        //然后通过比较器来实现排序
	        Collections.sort(list,new Comparator<Map.Entry<Integer,Integer>>() {
	        	@Override
	        	//升序排序
				public int compare(java.util.Map.Entry<Integer, Integer> o1, java.util.Map.Entry<Integer, Integer> o2) {
					return o2.getValue().compareTo(o1.getValue());
				}
	        });
	        int result = Integer.MAX_VALUE;
	        for(java.util.Map.Entry<Integer, Integer> mapping:list){ 
	        	boolean flag = true;
	        	int min = 0;
	               System.out.println(mapping.getKey()+":"+mapping.getValue()); 
	               for (int i = 0; i < A.length; i++) {
					if(A[i] != mapping.getKey()){
						if(B[i] != mapping.getKey()){
							flag = false;
							break;
						}else {
							min ++;
							
						}
					}
				}
	               if(flag){
	            	   if(min != 0){
	            		   result = Math.min(min, result);
	            	   }
	               }
	          } 
	     if(result == Integer.MAX_VALUE){
	    	  return -1;
	      }
	      //看B的值
	    //要想找到最小的那么首先需要找到出现次数最多的数字
			 Map<Integer, Integer> mapB = new TreeMap<>();
			 for (int i : B) {
				mapB.put(i, mapB.getOrDefault(i, 0) + 1);
			}
		  	//这里将map.entrySet()转换成list
		        List<Map.Entry<Integer ,Integer>> listB = new ArrayList<Map.Entry<Integer,Integer>>(map.entrySet());
		        //然后通过比较器来实现排序
		        Collections.sort(listB,new Comparator<Map.Entry<Integer,Integer>>() {
		        	@Override
		        	//升序排序
					public int compare(java.util.Map.Entry<Integer, Integer> o1, java.util.Map.Entry<Integer, Integer> o2) {
						return o2.getValue().compareTo(o1.getValue());
					}
		            
		        });
		       
		        int resultB = Integer.MAX_VALUE;
		        
		        for(java.util.Map.Entry<Integer, Integer> mapping:listB){ 
		        	boolean flag = true;
		        	int min = 0;
		               System.out.println(mapping.getKey()+":"+mapping.getValue()); 
		               for (int i = 0; i < B.length; i++) {
						if(B[i] != mapping.getKey()){
							if(A[i] != mapping.getKey()){
								flag = false;
								break;
							}else {
								min ++;
								
							}
						}
					}
		               if(flag){
		            	   if(min != 0){
		            		   resultB = Math.min(min, resultB);
		            	   }
		               }
		          } 
		       return Math.min(result, resultB);
    }
}

可以说很冗余了
看看这个代码:
有待学习

class Solution {
    public int minDominoRotations(int[] A, int[] B) {
        int min= A.length;
        for(int n=1; n<=6;n++){
            int Acount=0, Bcount=0;
            boolean flag = true;
            for (int i=0; i<A.length; i++){
                if (A[i]!=n && B[i]!=n){
                    flag=false;
                    break;
                }else {
                    if (A[i]==n){
                        Acount++;
                    }
                    if (B[i]==n){
                        Bcount++;
                    }
                }
            }
            if (flag){
                int Max = Math.max(Acount,Bcount);
                if (A.length-Max < min){
                    min=A.length-Max;
                }
            }
        }
        if (min!=A.length){
            return min;
        }
        return -1;
    }
}

【源码免费下载链接】:https://renmaiwang.cn/s/2gdnj 《R语言数据挖掘方法及应用》由薛薇编写而成的一本系统阐述R语言在数据挖掘领域前沿技术的著作。该书旨在指导读者学会使用R语言进高效、实用的数据分析与建模工作,涵盖了从理论基础到实践操作的全过程。作为一款功能强大且开源的统计计算和图形处理平台,R语言凭借其丰富的工具库和社区支持,在数据分析与可视化方面展现出显著优势。在数据挖掘领域,R语言提供了包括`caret`、`randomForest`、`tm`、`e1071`等广泛使用的专用包,这些工具能够帮助用户更便捷地进数据预处理、特征选择、模型构建和结果评估。全书首先介绍R语言的基本知识体系,涵盖环境配置与安装方法、基础语法规范以及常见数据类型分析等内容。这些基础知识是开展后续数据分析工作的必备技能,通过学习可以快速掌握R语言的核心功能。随后章节深入讲解了数据挖掘的主要概念与流程,包括数据清洗、转换整理和探索性分析等环节,同时详细阐述了分类、聚类、关联规则挖掘及预测等多种典型任务的具体实施方法。这些内容有助于读者全面理解数据挖掘的整体架构及其核心工作步骤。在应用实践部分,薛薇老师结合真实案例展示了R语言在实际业务场景中的具体运用,例如市场细分分析、客户流失预测以及个性化推荐系统等。通过这些案例研究,读者可以深入学习如何利用相关工具包解决实际问题,并提升数据分析能力。此外,书中配套的“案例数据集”和“代码资源”为读者提供了实践操作的机会,使理论知识能够更好地转化为动手技能。通过实际操作分析,读者可以加深对R语言数据挖掘方法的理解并灵活运用。总之,《R语言数据挖掘方法及应用》是一部全面讲解R语言在数据分析与建模领域的教材,无论你是刚开始学习的新人还是经验丰富的专业人士,都能从中获益匪浅。通过深入研读此书,你可以掌握R语言的数据挖掘技巧,并将其应用到实
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值