zoukankan      html  css  js  c++  java
  • Collections练习之对字符串先折半,再取最长的一个

       不多说,直接上干货!

    代码需求

       由

    [aa, abcde, cba, cba, nbaa, zzz]

      变成

    max=abcde

    CollectionsDemo.java

    package zhouls.bigdata.DataFeatureSelection.test;
    
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Comparator;
    import java.util.List;
    import java.util.TreeSet;
    import zhouls.bigdata.DataFeatureSelection.test.ComparatorByLength;
    
    public class CollectionsDemo {
        /**
         * @param args
         */
        public static void main(String[] args) {
            /*
             * Collections:是集合框架的工具类。
             * 里面的方法都是静态的。
             */
            demo();
        }
        
        public static void demo(){
            List<String> list = new ArrayList<String>();
            list.add("abcde");
            list.add("cba");
            list.add("aa");
            list.add("zzz");
            list.add("cba");
            list.add("nbaa");
            Collections.sort(list);
            System.out.println(list);
            //获取最大值。
            String max = Collections.max(list,new ComparatorByLength());
            System.out.println("max="+max);
        }
        
        public static <T> void mySort(List<T> list,Comparator<? super T> comp){
            for (int i = 0; i < list.size()-1; i++) {
                for (int j = i+1; j < list.size(); j++) {
                    if(comp.compare(list.get(i), list.get(j))>0){    
                        T temp = list.get(i);
                        list.set(i, list.get(j));
                        list.set(j, temp);
                        Collections.swap(list, i, j);
                    }
                }
            }
        }
        
        public static <T extends Comparable<? super T>> void mySort(List<T> list){ 
            for (int i = 0; i < list.size()-1; i++) {
                for (int j = i+1; j < list.size(); j++) {
                    if(list.get(i).compareTo(list.get(j))>0){    
                        T temp = list.get(i);
                        list.set(i, list.get(j));
                        list.set(j, temp);
                        Collections.swap(list, i, j);
                    }
                }
            }
        }
    }
  • 相关阅读:
    设计模式——模板方法模式
    设计模式——适配器模式
    设计模式——策略模式
    设计模式——工厂模式
    设计模式——代理模式
    设计模式——单例模式
    设计模式——总纲
    Hadoop的safeMode
    MapReduce中Combiner规约的作用以及不能作为MR标配的原因
    hdfs shell
  • 原文地址:https://www.cnblogs.com/zlslch/p/7576980.html
Copyright © 2011-2022 走看看