第一种方法(只学到数组的看):

定义一个新的数组长度和旧数组的长度一样,存储除去重复数据的旧数组的数据和0,

package demo01;

import java.sql.Array;
import java.util.Arrays;
/*JAVA数组去重**/
public class ArrayQC {
public static void main(String[] args) {
// 获取一个无重复元素的数组
int[] arr = new int[] { 11, 22, 22, 33, 44, 55, 44, 66, 66, 66 };
// 先确定新数组的长度
int[] newArr = new int[arr.length]; int index = 0; // 新数组存储元素索引(或者说无重复的个数) outer: for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {
//当数据重复时,跳出外圈循环
if (arr[i] == arr[j]) {
//System.out.println("arr[i]:"+arr[i]+"arr[j]:"+arr[j]);
continue outer;
}
}
// 后面没有与当前元素重复的值,保存这个数
//System.out.println("for内的index:"+index);
newArr[index] = arr[i];
index++;
}
// 新数组中存储着无重复的值和后面一些无效的0
//System.out.println("index:"+index);
int[] result = new int[index];
for (int i = 0; i < index; i++) { // 遍历有效值个数
result[i] = newArr[i];
}
System.out.println(Arrays.toString(result));
} }

第二中方法:

 /* 第二种方法:
*
* 一个一个删除,有一个删一个.
* 把数组中的一个数据和其他数据进行比较,如果有一个重复时,就直接开始创建新数组把重复的元素去除,并重新赋给旧数组
*/ public static void main(String[] args) { int[] arr = { 1, 1, 1, 1, 5, 3, 3, 4, 8, 8, 8, 8 }; // 1, 5, 3, 4, 8 for (int i = 0; i < arr.length; i++) { for (int j = i + 1; j < arr.length; j++) { if (arr[i] == arr[j]) {
//System.out.println("arr[i]:"+arr[i]+",arr[j]"+arr[j]);
// return返回的数字的地址而非数组的数值(不懂的华看一下变量的 名 和所代表的数据地址的关系)
arr = aa(arr, j);
// 改变的数组中新数据顶替了覆盖数组的就数据,所以还要重新比较一次 // { 1, 1, 1, 1, 5, 3, 3, 4, 8, 8, 8, 8 }; 下标 0 1 2
// 当下标为1被删除了 ,下标2的数据补上 0 2 这个新元素还没有被比较,所以要再比较一次,所以j--
//System.out.println("j:"+j);
j--;
}
}
} for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
} } // 需要获得旧数组和重复元素的下标,然后改成新数组并返回出来新数组
public static int[] aa(int[] arr, int index) { // 新数组,每发现一个就去除一个.所以长度-1 就行
int[] newArr = new int[arr.length - 1];
// 因为就数组的下标要去除一个,又不知道那个,所以定义一个变量自增来当新数组的下标
int c = 0;
for (int i = 0; i < arr.length; i++) {
// 判断传进来的那个重复的下标和数组中的下标相等时,下标的元素就不用重新赋给新数组了
if (index != i) {
newArr[c] = arr[i];
c++;
}
}
//System.out.println("newArr:"+newArr.toString());
//bl(newArr);
return newArr;
} //遍历数组
//public static void bl(int[] arr){
// for(int i = 0 ; i < arr.length ; i++){
// System.out.print(arr[i]+ ", ");
// }
//}

第三种方法;

    /**第三种方法:
*
* 相同的一起删除,当发现相同的元素,先统计重复的个数,然后一起删掉,得到新数组赋给旧数组 */ public static void main(String[] args) { int[] arr = { 8, 1, 1, 1, 1, 5, 3, 3, 4, 8, 8, 8, 8 }; arr = a2(arr); for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
} public static int[] a2(int[] arr) { int a = 0; for (int i = 0; i < arr.length - 1; i++) { for (int j = i; j < arr.length - 1; j++) { // 如果有相同的,就统计出相同元素的个数
if (arr[i] == arr[j + 1]) {
a += 1;
}
}
if (a != 0) {
// return返回的数字的地址而非数组的数值(不懂的华看一下变量的 名 和所代表的数据地址的关系)
arr = a1(arr, arr[i], a);
// 一个元素个数获得到,统计变量清零,等待回去下一个元素重复的个数
a = 0;
}
}
System.out.print("方法a2:");
bl(arr);
return arr;
} // 删除里面重复的元素
public static int[] a1(int[] arr, int arr2, int a) {
// 因为就数组的下标要去除一个,又不知道那个,所以定义一个变量自增来当新数组的下标
int c = 1;
// 获得新数组的长度,就是旧数组减去元素重复的次数
int[] aa = new int[arr.length - a];
// 重复的元素也要保留一个
aa[0] = arr2;
for (int i = 0; i < arr.length; i++) {
// 不与重复元素相同的元素都非给新数组
if (arr2 != arr[i]) {
aa[c++] = arr[i];
}
}
System.out.print("方法a1:");
bl(aa);
return aa;
} //遍历数组
public static void bl(int[] arr){
for(int i = 0 ; i < arr.length ; i++){
System.out.print(arr[i] + ", ");
}
System.out.println("数组遍历完毕。");
}

参考文档: https://blog.csdn.net/binLi_Cheng/article/details/81383197

(PASS)JAVA数组去重 三种方法 (不用集合)的更多相关文章

  1. 斐波那契数列-java编程:三种方法实现斐波那契数列

    题目要求:编写程序在控制台输出斐波那契数列前20项,每输出5个数换行 斐波那契数列指的是这样一个数列:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, … 这个数列 ...

  2. Eclipse远程调试Java代码的三种方法

    Eclipse远程调试Java代码的三种方法, 第1种方法是用来调试已经启动的Java程序,Eclipse可以随时连接到远程Java程序进行调试, 第2种方法可以调试Java程序启动过程,但是Ecli ...

  3. Java 数组的三种创建方法,数组拷贝方法

    public static void main(String[] args) {//创建数组的第一种方法int[] arr=new int[6];int intValue=arr[5];//Syste ...

  4. Java 数组的三种创建方法

    public static void main(String[] args) { //创建数组的第一种方法 int[] arr=new int[6]; int intValue=arr[5]; //S ...

  5. js数组去重五种方法

    今天来聊一聊JS数组去重的一些方法,包括一些网上看到的和自己总结的,总共5种方法(ES5). 第一种:遍历数组法 这种方法最简单最直观,也最容易理解,代码如下: var arr = [2, 8, 5, ...

  6. {转}Java 字符串分割三种方法

    http://www.chenwg.com/java/java-%E5%AD%97%E7%AC%A6%E4%B8%B2%E5%88%86%E5%89%B2%E4%B8%89%E7%A7%8D%E6%9 ...

  7. Java数组的三种打印方式

    1.数组的输出的三种方式 一维数组: 定义一个数组 int[] array = {1,2,3,4,5}; (1)传统的for循环方式 for(int i=0;i<array.length;i++ ...

  8. java script 数组去重两种方法

    第一种方法: var arr=[1,1,2,3,4,4,4,5,6,6,6,6];    var arrb=Array();    for(var i=0;i<arr.length;i++)   ...

  9. Java创建数组的三种方法

    ■ 第一种: int[] arr=new int[6]; arr[0] = 1; arr[1] = 2 arr[2] = 3; arr[3] = 4; arr[4] = 5; arr[5] = 6; ...

随机推荐

  1. 手写9x9乘法表,冒泡排序

    手写9x9乘法表,冒泡排序 9x9乘法表 class Demo {public static void main(String[] args) {for(int x = 0;x <= 9; x+ ...

  2. bzoj2004 [Hnoi2010]Bus 公交线路 矩阵快速幂+状压DP

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=2004 题解 如果 \(N\) 没有那么大,考虑把每一位分配给每一辆车. 假设已经分配到了第 \ ...

  3. BZOJ3514 Codechef MARCH14 GERALD07加强版 LCT维护最大生成树 主席树

    题面 考虑没有询问,直接给你一个图问联通块怎么做. 并查集是吧. 现在想要动态地做,那么应该要用LCT. 考虑新加进来一条边,想要让它能够减少一个联通块的条件就是现在边的两个端点还没有联通. 如果联通 ...

  4. Boyer-Moore

    Boyer-Moore 只做这些失败的匹配,就可以排除掉相应的对齐位置.在BM算法中,模式串P与文本串T的对准位置依然自左向右移动,而在对准位置确是自右向左的逐一比对各个字符串,具体的,在每一轮自右向 ...

  5. pandas模块之读取文件

    首先我们来看一个文件 1 男 北京 刘一 我笑 #跳过此行,序号1 2 女 上海 刘珊 你笑 3 男 杭州 刘五 他笑 #跳过此行,序号四 4 女 重庆 刘六 不笑了 下面来分析内容,并使用参数 1 ...

  6. 课下选作Main dc

    一.中后缀定义: 中缀表达式:我们平时写的数学表达式一般为中缀表达式,如"5+2(3(3-12+1))",直接拿中缀表达式直接让计算机计算表达式的结果并不能做到. 后缀表达式:把中 ...

  7. (转)JVM运行时数据区

    转:http://www.cnblogs.com/myna/p/7567208.html java虚拟机运行时数据区,具体分为如下几个区域 程序计数器(Program Counter Register ...

  8. python接口自动化测试三十五:用BeautifulReport生成报告

    GitHub传送门:https://github.com/TesterlifeRaymond/BeautifulReport 配置BeautifulReport 下载.解压并修改名字为Beautifu ...

  9. 面试题30:包含min函数的栈

      思路: 1.首先将栈的基本结构写出 #初始化栈的写法 def __init__(self): self.stack = [] #栈的压入 (加self是实例化,如果前面加入静态装饰器啥的,就不需要 ...

  10. linux下部署springboot vue项目

    使用的工具是 XFTP5 XSHELL5 docker pull gmaslowski/jdk 拉取jdk docker images 查询下载的镜像ID (如:390b58b1be42) docke ...