解析、查找数组中重复出现的元素(Java)

简介: 解析、查找数组中重复出现的元素,Java实现。《数据结构与算法分析:解析、查找数组中重复出现的元素》问题描述:一个结构化数据,假设事先按照某种顺序排好序(比如升序)的一个数组中,无规则、重复出现若干次某个相同...


解析、查找数组中重复出现的元素,Java实现。

《数据结构与算法分析:解析、查找数组中重复出现的元素》


问题描述:一个结构化数据,假设事先按照某种顺序排好序(比如升序)的一个数组中,无规则、重复出现若干次某个相同元素,形如有序数组data:

data = {  "A", "A", "B", "C", "C", "D", "D" , "D"  }

data数组中,事先已经按照 A -> Z 升序排好,但是数组内部的数据元素无规则重复出现:
’A’在数组位置0,1(注:0,1指下标,下同)重复出现两次;
’B’没有重复;
’C’在数组位置3,4重复出现两次;
’D’在5,6,7位置重复出现三次。

针对这样的数据结构,设计算法并代码实现查找、分析数组中重复出现的元素。

算法的应用场景:这种算法的应用场景之一就是在通讯录联系人的操作中将被涉及。比如在我之前写的一篇文章:《Android基于PinnedSectionListView实现联系人通讯录》(链接地址: http://blog.csdn.net/zhangphil/article/details/47271741 ,此文涉及到通讯录分类整理,需要按照联系人姓氏的首字符排序分组)。通常,一个手机的通讯录中存有若干个联系人,每个联系人都有姓,如果按照姓氏的首字符(比如,中文姓’张’,Zhang,首字符为’Z’)排成升序,将构成形如上述data数组的数据结构,进而对联系人进行分组。比如,都是张姓联系人,则都归入到’Z’组下,从而便于用户快速定位查找通讯录中个某一张姓联系人。因此,将此现实中的应用场景建立数据模型,就是本文算法所要解决的计算问题。
现给出一个代码实现(Java)的算法:

import java.util.ArrayList;

public class Test {

	// 原始数据data。假设data数组中的数据元素已经按照某种顺序排好。
	// 但是,该数组中的数据元素重复出现。
	// 我们的目的是查找、解析data数组中重复出现的某元素。
	// 比如,在这个data数组中,元素'C'在数组位置2,3重复出现两次。
	// 注意!有些元素没有重复出现,比如元素'B'。
	private String[] data = { "A", "A", "B", "C", "C", "D", "D", "D" };

	// 存储分类好的数据元素。
	private ArrayList<Group> groups = new ArrayList<Group>();

	// 核心的算法实现。
	public void find() {

		// 游标index
		int index = 0, j = 0;

		while (index < data.length) {
			Group group = new Group();
			group.title = data[index];
			
			String t = group.title;

			ArrayList<String> children = new ArrayList<String>();

			for (j = index; j < data.length; j++) {

				String child = data[j];
				if (t.equals(child)) {
					// 同时记录该重复出现的元素在原数组中的下标j,便于查验、评估结果。
					children.add(child + "@" + j);
				} else {
					break;
				}
			}

			// 往后推进游标index
			index = j;

			group.children = children;
			groups.add(group);
		}
	}

	// 输出结果。
	private void print() {
		for (int i = 0; i < groups.size(); i++) {
			Group g = groups.get(i);
			System.out.println(g);
		}
	}

	// 自己构造一个类,作为一组数据的容器。
	// 该类用一个title表明这一group数据是归属于那个重复元素的组。
	// 该title下重复的元素装入到ArrayList<String> children中,供遍历查询。
	private class Group {
		public String title;
		public ArrayList<String> children;

		// 结果。
		@Override
		public String toString() {
			String str = "组" + title + ": ";
			for (int i = 0; i < children.size(); i++) {
				str += children.get(i) + " ";
			}

			return str;
		}
	}

	public static void main(String args[]) {
		Test t = new Test();
		t.find();
		t.print();
	}
}


结果输出:

组A: A@0 A@1 
组B: B@2 
组C: C@3 C@4 
组D: D@5 D@6 D@7 

相关文章
|
10天前
|
Java
Java中ReentrantLock释放锁代码解析
Java中ReentrantLock释放锁代码解析
25 8
|
13天前
|
人工智能 Java
Java练习题-输出二维数组对角线元素和
Java练习题-输出二维数组对角线元素和
19 1
|
3天前
|
存储 索引 Python
深入解析NumPy数组的形状与重塑
【4月更文挑战第17天】本文深入解析了NumPy数组的形状和重塑。数组形状是表示数组维度和大小的元组,可通过`shape`属性获取。重塑允许改变数组形状而不改数据,需保证元素总数不变。`reshape`方法用于重塑,其中`-1`可让NumPy自动计算尺寸。注意重塑遵循元素总数相等、仅一次`-1`、内存存储顺序及返回新数组的原则。理解和掌握这些概念对高效使用NumPy处理多维数组至关重要。
|
3天前
|
Java API 数据库
深入解析:使用JPA进行Java对象关系映射的实践与应用
【4月更文挑战第17天】Java Persistence API (JPA) 是Java EE中的ORM规范,简化数据库操作,让开发者以面向对象方式处理数据,提高效率和代码可读性。它定义了Java对象与数据库表的映射,通过@Entity等注解标记实体类,如User类映射到users表。JPA提供持久化上下文和EntityManager,管理对象生命周期,支持Criteria API和JPQL进行数据库查询。同时,JPA包含事务管理功能,保证数据一致性。使用JPA能降低开发复杂性,但需根据项目需求灵活应用,结合框架如Spring Data JPA,进一步提升开发便捷性。
|
8天前
|
Java
Java 15 神秘登场:隐藏类解析未知领域
Java 15 神秘登场:隐藏类解析未知领域
12 0
|
8天前
|
安全 Java 编译器
接口之美,内部之妙:深入解析Java的接口与内部类
接口之美,内部之妙:深入解析Java的接口与内部类
25 0
接口之美,内部之妙:深入解析Java的接口与内部类
|
22天前
|
Java
java 8 数组转字符串并以逗号分隔
java 8 数组转字符串并以逗号分隔
11 0
|
26天前
|
存储 算法 Serverless
【软件设计师备考 专题 】数据结构深度解析:从数组到图
【软件设计师备考 专题 】数据结构深度解析:从数组到图
56 0
|
26天前
|
Java 程序员 C#
静态构造方法解析,Java新手必看技能
静态构造方法解析,Java新手必看技能
8 0
|
1天前
|
安全 Java
深入理解 Java 多线程和并发工具类
【4月更文挑战第19天】本文探讨了Java多线程和并发工具类在实现高性能应用程序中的关键作用。通过继承`Thread`或实现`Runnable`创建线程,利用`Executors`管理线程池,以及使用`Semaphore`、`CountDownLatch`和`CyclicBarrier`进行线程同步。保证线程安全、实现线程协作和性能调优(如设置线程池大小、避免不必要同步)是重要环节。理解并恰当运用这些工具能提升程序效率和可靠性。

推荐镜像

更多