迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

计算 Java 数组中的重复元素

作者:迹忆客 最近更新:2023/05/01 浏览次数:

本篇文章介绍Java计算数组中重复元素的方法。


计算 Java 数组中的重复元素

我们可以创建一个程序来计算数组中的重复元素。 该数组可以是未排序的,也可以是已排序的。

本教程演示了对已排序和未排序数组中的重复元素进行计数的方法。

按照以下步骤计算数组中重复的元素:

  • 首先,获取输入数组。
  • 然后,创建一个临时数组。
  • 下一步是遍历输入数组。
  • 遍历时检查临时数组中是否存在当前元素。 然后我们需要跳过检查当前元素。
  • 如果当前元素不可用,则继续比较当前元素和所有下一个元素。
  • 如果在任何阶段找到匹配项,则将该元素添加到临时数组。
  • 最后一步是显示临时数组中重复元素的总数。

让我们在 Java 代码中实现上述步骤:

package jiyik;

public class Example {

    public static void main(String[] args) {

        int InputArray[] = { 100, 220, 100, 400, 200, 100, 200, 600, 400, 700};
        int TemporaryArray[] = new int[InputArray.length];
        int RepeatCount = 0;

        for(int x=0; x<InputArray.length; x++) {
            int element = InputArray[x];
            boolean flag = false;
            for(int y=0; y<RepeatCount; y++) {
                if(TemporaryArray[y] == element) {
                    flag = true;
                    break;
                }
            }

            if(flag) {
                continue;
            }

            for(int y=x+1; y<InputArray.length; y++) {
                if(InputArray[y] == element) {
                    TemporaryArray[RepeatCount++] = element;
                    break;
                }
            }
        }

        System.out.println("The Total Repeated elements in the array: " + RepeatCount);
        System.out.println("The Repeated elements are : ");
        for (int x = 0; x < RepeatCount; x++) {
            System.out.print(TemporaryArray[x]+" ");
        }
    }
}

上面的代码将计算重复的数字,然后打印它们。 查看输出:

The Total Repeated elements in the array: 3
The Repeated elements are :
100 400 200

以上内容适用于已排序和未排序的数组。 但是为了更加简化,我们可以创建一个只适用于排序数组的程序。

看例子:

package jiyik;

public class Example {

    public static void main(String[] args) {


        int InputArray[] = { 100, 100, 100, 200, 200, 220, 400, 400, 600, 700};
        int TemporaryArray[] = new int[InputArray.length];
        int RepeatCount = 0;

        for (int x = 1; x < InputArray.length; x++) {

            int element = InputArray[x];
            if(element == TemporaryArray[RepeatCount]) {
                continue;
            }

            for (int y = x + 1; y < InputArray.length; y++) {
                if (InputArray[y] == element) {
                    TemporaryArray[RepeatCount++] = element;
                    break;
                }
            }
        }

        System.out.println("The Total Repeated elements in the array: " + RepeatCount);
        System.out.println("The Repeated elements are : ");
        for (int x = 0; x < RepeatCount; x++) {
            System.out.print(TemporaryArray[x] + " ");
        }
    }
}

现在,这个程序可以很好地处理排序后的数组。 它是更简化的版本。

查看输出:

The Total Repeated elements in the array: 3
The Repeated elements are :
100 200 400

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 Java 中获取文件大小

发布时间:2023/05/01 浏览次数:139 分类:Java

Java 提供了不同的方法来获取文件的字节大小。 本教程演示了在 Java 中获取文件大小的不同方法。使用 Java IO 的文件类获取文件大小 Java IO 包的 File 类提供了以字节为单位获取文件大小的功能。

Java 中的文件分隔符

发布时间:2023/05/01 浏览次数:108 分类:Java

本篇文章介绍了 Java 中的文件分隔符。Java 中的文件分隔符 文件分隔符是用来分隔目录的字符; 例如,Unix 使用 /,Windows 使用 \ 作为文件分隔符。

Java 中的文件过滤器

发布时间:2023/05/01 浏览次数:193 分类:Java

本篇文章介绍如何在 Java 中使用 FileFilter。FileFilter 用于过滤具有特定扩展名的文件。 Java内置包IO和Apache Commons IO为FileFilter提供了类和接口来进行文件过滤操作。

Java 获取 ISO 8601 格式的当前时间戳

发布时间:2023/05/01 浏览次数:132 分类:Java

本篇文章介绍了 ISO 8601 日期格式、其重要性及其在 Java 中的使用。 它还列出了一些优点来强调为什么应该使用 ISO 格式来表示日期。

在 Java 中获取数组的子集

发布时间:2023/05/01 浏览次数:142 分类:Java

本篇文章介绍了几种在 Java 中获取数组子集的方法。使用 Arrays.copyOf() 方法获取数组的子集 使用 Arrays.copyOfRange() 方法获取数组的子集

用 Java 填充二维数组

发布时间:2023/05/01 浏览次数:110 分类:Java

二维数组是基于表结构的,即行和列,填充二维数组不能通过简单的添加到数组操作来完成。 本篇文章介绍如何在 Java 中填充二维数组。

Java 中的自然排序

发布时间:2023/05/01 浏览次数:132 分类:Java

Java 中最常用的顺序是自然顺序。 本文将展示如何使用 naturalOrder() 函数对数组进行排序。

Java 中 List 和 Arraylist 的区别

发布时间:2023/05/01 浏览次数:90 分类:Java

表示为单个单元的一组单个对象称为集合。 在 Java 中,Collection 是一个具有多个已定义接口和类的框架,用于将一组对象表示为一个单元。 它允许我们操纵

Java 中的 Vector 和 ArrayList

发布时间:2023/05/01 浏览次数:52 分类:Java

ArrayList 和 Vector 都实现了 List 接口,都可以作为内部数据结构的数组。 但是,尽管它们大部分相同,但它们也有不同之处。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便