一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java學習之一維數組中重復元素的去除

java學習之一維數組中重復元素的去除

2022-01-05 11:01趙清詩 Java教程

關于一維數組中有重復的元素該怎么剔除,作為java初學者的我整理出不調用任何特殊庫的基礎方法,這種思想在其他語言也適用,有需要的朋友可以借鑒參考下

一、基本思路

首先,假設一個一維數組arr[ ]={ 4, 3, 35, 3, 2, 4, 6, 3},其中有三個重復元素 3,4,3。要如何剔除呢,由于還沒有涉獵到一些經典的調用,所以我選擇了用新的數組newArr[ ]去繼承原來數組中的不重復的元素,另外還需要一個判斷數組Arr[ ],來判斷arr[ ]中哪幾個元素是重復的,才好去除掉。

二、步驟

1.設置判斷數組Arr[ ]

代碼如下(示例):

?
1
2
3
4
5
6
7
8
9
10
11
12
int[] arr = { 4, 3, 35, 3, 2, 4, 6, 3 };
        int[] Arr = new int[arr.length];
        for (int i = 0; i < arr.length-1; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] == arr[j]) {
                    Arr[j] = 1;         //把Arr中元素下標和arr中元素下標一致的元素,賦值為1,來標記判斷重復元素的位置(下標)
                }
            }
        }`
        // //測試一下相同元素的位置
        for (int i = 0; i < Arr.length; i++) {
            System.out.print(Arr[i]);

初始化一個長度和arr相同的數組Arr={0,0,0,0,0,0,0,0},用兩層嵌套for循環來判斷各重復元素:外層循環控制比較輪數,內層循環控制不同的兩個元素之間的比較。(其實總體過程就是首先第一個元素和后面比較是否重復,然后第二輪是從第二個元素開始依次和右邊剩下的各個元素開始比較,第三輪…第n輪…

eg: i=0時,進入外層循環,第一輪比較:以arr[i]=arr[0]=4為基準開始比較,
進入內層循環,再進行比較:
(1)arr[j]=arr[i+1]=arr[1]=3,3!=4,不重復,
(2)arr[j+1]=arr[i+2]=arr[2]=35,35!=4,不重復,
(3)arr[j+2]=arr[i+3]=arr[3]=3, 3!=4,不重復 ,
(4)arr[j+3]=arr[i+4]=arr[4]=2, 2!=4,不重復 ,
(5)arr[j+4]=arr[i+5]=arr[5]=4, 4==4,重復 ,

此時找到了一個重復的元素4,然后同樣的
i=1時,以arr[i]=arr[1]=3為基準進入第二輪比較,可以找到重復元素arr[3]=3,arr[7]=3,都是重復元素
i=…時,一直重復arr.length(數組的長度)輪比較,最終找出重復元素只有三個,就是3,4,3。
注意到: // //測試一下相同元素的位置
for (int i = 0; i < Arr.length; i++) {
System.out.print(Arr[i]);
其實這一步不必要,但是為了直觀顯示出重復元素的位置,我輸出了判斷數組Arr,輸出結果是 0 0 0 1 0 1 0 1,很清晰的看出原數組arr中哪三個位置的元素重復了的

2.繼承數組newArr[ ]獲取不重復元素

就是剔除重復元素的步驟

?
1
2
3
4
5
6
7
8
System.out.println();
    int count = 0;
    for (int i = 0; i < Arr.length; i++) {
        if (Arr[i] == 0) {
            count++;
        }
        System.out.println("不重復元素的個數有" + count + "個");
    int[] newArr = new int[count];

(1)遍歷判斷數組Arr[ ],遍歷到0元素的時候,計數器count+1,count數就是不重復元素個數,就是繼承數組newArr[ ]的長度。
(2) 設置計數器 index 初始化=0,for循環遍歷判斷數組Arr[ ],通過if條件語句。如果Arr[ ]=0,說明在該位置下的原數組元素是不重復的,則執行newArr[index++] = arr[i];(把原數組中不重復的元素繼承給newArr)

?
1
2
3
4
5
6
7
8
9
int index = 0;
        for (int i = 0; i < Arr.length; i++) {
            if (Arr[i] == 0) {
                newArr[index++] = arr[i];
            }
}
        for (int i = 0; i < newArr.length; i++) {
            System.out.print(newArr[i] + " ");
        }

(3)for循環遍歷繼承數組newArr[ ],輸出結果就是去除重復元素后的最終結果。

總結

關鍵詞 :
判斷數組Arr[ ]:判斷數組中重復元素的位置(下標)。
繼承數組newArr[ ]:繼承去掉重復元素后剩下不重復的數組元素。
(以上兩個數組都是我自己方便理解取的名字)
以上就是我要介紹的全部內容,由于水平有限難免會有紕漏,希望能幫助到大家,大佬們歡迎批評指正。
附上完整代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
public class Array {
    public static void main(String[] args) {
        int[] arr = { 4, 3, 35, 3, 2, 4, 6, 3 };
        int[] Arr = new int[arr.length];
           //<arr.length-1防止數組越界
        for (int i = 0; i < arr.length-1; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] == arr[j]) {
                    Arr[j] = 1;
                }
            }
        }
        // //測試一下相同元素的位置
        for (int i = 0; i < Arr.length; i++) {
            System.out.print(Arr[i] + " ");
        }
        System.out.println();
        int count = 0;
        for (int i = 0; i < Arr.length; i++) {
            if (Arr[i] == 0) {
                count++;
            }
        }
        System.out.println("不重復元素的個數" + count);
        int[] newArr = new int[count];
        int index = 0;
        for (int i = 0; i < Arr.length; i++) {
            if (Arr[i] == 0) {
                newArr[index++] = arr[i];
            }
        }
            System.out.println("去除掉重復元素后的數組:");
        for (int i = 0; i < newArr.length; i++) {
            System.out.print(newArr[i] + " ");
        }
    }
}

輸出結果:

java學習之一維數組中重復元素的去除

以上就是java學習之一維數組中重復元素的去除的詳細內容,更多關于java一維數組的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/qq_51964402/article/details/115607489

延伸 · 閱讀

精彩推薦
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
主站蜘蛛池模板: 精品网站一区二区三区网站 | 男人和女人日 | 高清不卡免费一区二区三区 | 成人免费淫片95视频观看网站 | 精品国产免费 | 四虎影院观看 | 污漫日本E同人 | 美女被吸乳得到大胸 | 九九在线精品亚洲国产 | 久久精视频 | 91精品国产高清久久久久久io | 日韩夫妻性生活 | 亚洲国产三级在线观看 | 亚洲va国产日韩欧美精品色婷婷 | 美女被躁爽死 | 日韩欧美一区二区三区免费观看 | 蜜桃久久久亚洲精品成人 | 亚洲区精品 | 亚洲一区二区三区福利在线 | 亚洲波霸 | 美女脱了内裤打开腿让人桶网站o | 校花小雪灌满了男人们的浓浆 | 欧洲破处 | 精品国产福利在线观看一区 | 青久草视频 | 国产成人在线播放视频 | 国产一卡2卡3卡四卡高清 | 欧美精品一线二线大片 | 亚洲精品αv一区二区三区 亚洲精品91大神在线观看 | 五月天婷婷网亚洲综合在线 | 天天夜夜啦啦啦 | 久久精品99国产精品日本 | 国产尤物精品视频 | 香蕉91| 爱情岛论坛亚洲品质自拍视频 | 久久九九亚洲精品 | 亚洲视频免费 | 91精品国产亚洲爽啪在线影院 | 亚洲妇熟xxxxx妇色黄 | 久久视热频国产这里只有精品23 | 天美影视传媒mv直接看 |