• 【java】查重类的实现


    import java.util.Vector;
     
    public class ElementCheck {
     
        // 重复优先
        static Vector<Integer> CheckSameElement1(Vector<String> test) {
            Vector<Integer> markA = new Vector();
            Vector<Integer> markB = new Vector();
            for (int i = 0; i < test.size(); i++) {
                markA.add(0);
            }
            for (int i = 0; i < test.size(); i++) {
                if (markA.get(i) != 1) {
                    for (int n = i + 1; n < test.size(); n++) {
                        if (markA.get(n) != 1) {
                            try {
                                if (test.get(i).equals(test.get(n))) {
                                    if (markA.get(i) != 1) {
                                        markB.add(i);
                                    }
                                    markA.set(n, 1);
                                    markA.set(i, 1);
                                    markB.add(n);
                                }
                            } catch (Exception e) {
                            }
                        }
                    }
                }
            }
     
            return markB;
        }
     
        // 序号排列优先
        static Vector<Integer> CheckSameElement2(Vector<String> test) {
            Vector<Integer> markA = new Vector();
            Vector<Integer> markB = new Vector();
            for (int i = 0; i < test.size(); i++) {
                markA.add(0);
            }
            int a = 0;
            for (int i = 0; i < test.size(); i++) {
                if (markA.get(i) != 1) {
                    for (int n = i + 1; n < test.size(); n++) {
                        if (markA.get(n) != 1) {
                            try {
                                if (test.get(i).equals(test.get(n))) {
                                    markA.set(n, 1);
                                    markA.set(i, 1);
                                }
                            } catch (Exception e) {
                            }
                        }
                    }
                }
            }
            for (int i = 0; i < test.size(); i++) {
                if (markA.get(i) == 1) {
                    markB.add(i);
                }
            }
            return markB;
        }
     
        static Vector<Integer> CheckDifferentElement(Vector<String> test) {
            Vector<Integer> markA = new Vector();
            Vector<Integer> markB = new Vector();
            for (int i = 0; i < test.size(); i++) {
                markA.add(0);
            }
            int a = 0;
            for (int i = 0; i < test.size(); i++) {
                if (markA.get(i) != 1) {
                    for (int n = i + 1; n < test.size(); n++) {
                        if (markA.get(n) != 1) {
                            try {
                                if (test.get(i).equals(test.get(n))) {
                                    markA.set(n, 1);
                                    markA.set(i, 1);
                                }
                            } catch (Exception e) {
                            }
                        }
                    }
                }
            }
            for (int i = 0; i < test.size(); i++) {
                if (markA.get(i) != 1) {
                    markB.add(i);
                }
            }
            return markB;
        }
    }

    类及方法的说明:

    类:ElementCheck

    CheckSameElement1(Vector<String> test)

    Vector<String> test:目标数组

    将目标数组中重复的元素的序号以Vector<Integer>类型返还,排序方式为重复优先

     

    CheckSameElement2(Vector<String> test)

    Vector<String> test:目标数组

    将目标数组中重复的元素的序号以Vector<Integer>类型返还,排序方式为序号排列优先

     

    CheckDifferentElement(Vector<String> test)

    Vector<String> test:目标数组

    将目标数组中不重复的元素的序号以Vector<Integer>类型返还

    ---------------------
    作者:小轩砸
    来源:CSDN
    原文:https://blog.csdn.net/m0_37459696/article/details/68939768
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    Alwayson 与 mirror
    cmd运行sql server安装
    搭建阿里云lnmp环境 (centos7+nginx+MySQL5.7.16+PHP7)
    php-fpm.conf 配置文件(实际项目中使用)
    编译安装php7.0.0
    Linux 服务器环境安装参考文档
    MySQL5.7 my.cnf 优化配置参数
    CentOS 7中源码安装MySQL 5.7.16 (亲测成功)
    mysql启动报错:Starting MySQL... ERROR! The server quit without updating PID file
    centos7下源码安装mysql5.7.16
  • 原文地址:https://www.cnblogs.com/xiaoshen666/p/11005005.html
Copyright © 2020-2023  润新知