当前位置:首页 > 学习笔记 > Java教程 > Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数

Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数

刘广法2022年03月15日 16:35:32Java教程10060
Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数-第1张图片-刘广法IT博客

Java课后作业:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数

问题1:判断两个数组中重叠的元素?

问题2:重叠的元素都重叠了几次,进行排序输出?

本题关键:去重(验证之前是否验证过此数)、排序,(冒泡排序法和选择排序法)、关键字break 和continue 的使用

	// Java课后作业:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数
	public static void main(String[] args) {
		// 定义一个整数数组a,再定义一个整数数组b,两个数组中的元素都有可能有重复元素
		// 问题1:统计两个数组a与b的交集(不存在重复元素),一定难度
		int[] a = { 1, 2, 2, 3, 1, 3, 2 };
		int[] b = { 2, 3, 5, 7, 5, 3, 2, 1 };

		// 定义一个数组c,用来储存数组a和数组b中重叠的元素
		int clength = a.length < b.length ? a.length : b.length;
		int c[] = new int[clength];
		// 定义一个数组下表位置,不定义的话,数组就会变成[1, 2, 3, 0, 0, 0, 0]
		int cInexs = 0;
		for (int i = 0; i < a.length; i++) {
			// 在遍历数组a的时候,看看前面有没有相同的元素,如果有,直接停止
			boolean isYes = false;
			for (int t = 0; t < i; t++) {
				if (a[i] == a[t]) {
					isYes = true;
					break;
				}
			}
			if (isYes) {
				continue;
			}
			for (int j = 0; j < b.length; j++) {
				if (a[i] == b[j]) {
					c[cInexs] = b[j];
					cInexs++;
					break;
				}
			}
		}
		// 问题2:按出现频率排序
		// 既然现在数组c中没有重复的元素,那么就把数组c中的每一个元素拿出出来分别计算一下在数组a和数组b中存在了几次,依次存在数组f中:
		int f[] = new int[cInexs];
		for (int i = 0; i < c.length; i++) {
			// 统计数组a中在我位置c[i]的数量放在f[i]中
			for (int n = 0; n < a.length; n++) {
				if (c[i] == a[n]) {
					f[i]++;
				}
			}
			// 统计数组b中在我位置c[i]的数量放在f[i]中
			for (int n = 0; n < b.length; n++) {
				if (c[i] == b[n]) {
					f[i]++;
				}
			}
		}
		// 统计出来了那就对数组f进行排序,排序的时候需要注意,数组c与数组f一一对应的关系
		// 排序法之冒泡法
//		System.out.println("没有排序之前的数组 c 和数组 f");
//		System.out.println(Arrays.toString(c));
//		System.out.println(Arrays.toString(f));
		
//		for (int i = 0; i < f.length; i++) {
//			for (int j = i; j < f.length - i - 1; j++) {
//				if (f[j] > f[j + 1]) {
//					int t = f[j + 1];
//					f[j + 1] = f[j];
//					f[j] = t;
//
//					t = c[j + 1];
//					c[j + 1] = c[j];
//					c[j] = t;
//				}
//			}
//		}
		// 排序法之选择排序法
		for (int i = 0; i < f.length - 1; i++) {
			for (int j = i - 1; j < f.length - 1; j++) {
				if (f[i] > f[j + 1]) {
					int t = f[j + 1];
					f[j + 1] = f[j];
					f[j] = t;

					t = c[j + 1];
					c[j + 1] = c[j];
					c[j] = t;
				}
			}
		}
//		System.out.println("排序之后的数组 c 和数组 f");
//		System.out.println(Arrays.toString(c));
//		System.out.println(Arrays.toString(f));
		// 最后进行输出:
		System.out.print("问题1重叠的元素有:");
		for (int i = 0; i < cInexs; i++) {
			System.out.print(c[i]+" ");
		}
		System.out.println();
		System.out.print("问题2重叠的元素对应的次数依次式");
		for (int i = 0; i < cInexs; i++) {
			System.out.print(f[i]+" ");
		}
	}

Java控制台输出结果:

问题1重叠的元素有:1 3 2 
问题2重叠的元素对应的次数依次式3 4 5


来源:刘广法博客,请注意转载出处,网站地址为:https://liuguangfa.com/

扫描二维码推送至手机访问。

版权声明:本文由刘广法博客发布,如需转载请注明出处。

本文链接:https://liuguangfa.com/java/119.html

分享给朋友:

“Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数” 的相关文章

使用eclipse进行文件的导入和导出

使用eclipse进行文件的导入和导出

该说不说,学会这个项目可以省很多的事情,刘广法可以用这个方法借鉴同学的项目,可以进行参考、借鉴、以及抄作业。一、使用eclipse进行项目的导出:1、使用eclipse进行项目的导出第一步:找到所在的项目工作空间,如果你知道的话,可以直接打开文件进行打包发送给你的好友,如果想要知道项目工作空间如何修...

java学习:Java流程控制语句的相关测试题

第一题:将所有包含3的三位数整数相加求和。103 131 133 301类似。public static void main(String[] args) { int n = 100;// 从n开始三位数...

eclipse 自动提示功能的实现

eclipse 自动提示功能的实现

之前用的版本都是有提示的,最近安装的最新版没有提示,今天就设置让自动提示出来第一步:windows”->"preferences",弹出preferences设置窗口。第二步:在preferences中找到Java,依次展开列表"Editor"->...

eclipse的快捷键功能

eclipse的快捷键功能

有一些快捷键是可以修改的,具体修改过程如图下:修改快捷的详细步骤:1、使用快捷键调出快捷键列表进行查看:快捷键列表调用:shift + ctrl + L2、window->preferences->general->keys(或直接搜索keys)快捷键列表:shuft + ctrl...

eclipse 如何更换JDK版本 替换自带的JDK版本

eclipse 如何更换JDK版本 替换自带的JDK版本

设置jdk,用安装的JDK替换eclipse自带的JDK(详细步骤)1、Window-->Presferences2、进入后,搜索“java”,找到“Installed JRES”3、删除自带的JDK:选中自带的jdk,然后选择remove。4、添加自己安装的JDK:选中右边的Add,选择St...

Java练习:找出三位数中所有的水仙花的值

找到三位数中所有为水仙花的值1、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。2、三位数中。具体的步骤:public static void main(String[] args) { int i =&nbs...

Java练习:打印出所有3位数的素数

课堂练习:打印出所有3位数的素数。素数:只能被1和其本身整除的数 public static void main(String[] args) { // 打印三位数的素数,素数只能被1和本身整数的数。 for (int...

Java学习 第五节:break和continue关键字

break和continue关键字break:表示中断,退出。退出当前一层循环。一旦break,后面的语句将不会得到执行。continue:中断本次循环,直接进行下一次的循环。continue后面的语句将不会得到执行。...

Java练习:控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成绩最小值

有控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成绩最小值 public static void main(String[] args) { // 有控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成...

Java教程第七节:选择排序法和和冒泡排序法

选择法排序:分为若干轮比较,每一轮找出一个最大值。刘广法整理思路:假设有数组{ 1, 2, 3, 5, 98, 24, 6, 456, 14 },假设第一个数字最大,然后从第二个开始依次和第一个比,如...

Java练习:定义一个函数,计算两个整数的最大公约数

Java面试题:定义一个函数,计算两个整数的最大公约数本题关键点:最大的公约数能够被两个数都整除的数 public static void main(String[] args) { // 定义一个函数,计算两个整数的最大公约数...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。