欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

C++有序數(shù)組中怎么去除重復(fù)項(xiàng)

這篇文章主要介紹“C++有序數(shù)組中怎么去除重復(fù)項(xiàng)”,在日常操作中,相信很多人在C++有序數(shù)組中怎么去除重復(fù)項(xiàng)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++有序數(shù)組中怎么去除重復(fù)項(xiàng)”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

防城網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。

Remove Duplicates from Sorted Array 有序數(shù)組中去除重復(fù)項(xiàng)

Given a sorted array nums, remove the duplicates in-place such that each element appear only once and return the new length.

Do not allocate extra space for another array, you must do this by modifying the input array in-place with O(1) extra memory.

Example 1:

Given nums = [1,1,2],

Your function should return length =

2

, with the first two elements of

nums

being

1

and

2

respectively.

It doesn"t matter what you leave beyond the returned length.

Example 2:

Given nums = [0,0,1,1,1,2,2,3,3,4],

Your function should return length =

5

, with the first five elements of

nums

being modified to 

0

,

1

,

2

,

3

, and 

4

respectively.

It doesn"t matter what values are set beyond the returned length.

Clarification:

Confused why the returned value is an integer but your answer is an array?

Note that the input array is passed in by reference, which means modification to the input array will be known to the caller as well.

Internally you can think of this:

// nums is passed in by reference. (i.e., without making a copy)
int len = removeDuplicates(nums);

// any modification to nums in your function would be known by the caller.
// using the length returned by your function, it prints the first len elements.
for (int i = 0; i < len; i++) {
print(nums[i]);
}

這道題要我們從有序數(shù)組中去除重復(fù)項(xiàng),和之前那道 Remove Duplicates from Sorted List 的題很類似,但是要簡單一些,因?yàn)楫吘箶?shù)組的值可以通過下標(biāo)直接訪問,而鏈表不行。那么這道題的解題思路是使用快慢指針來記錄遍歷的坐標(biāo),最開始時(shí)兩個(gè)指針都指向第一個(gè)數(shù)字,如果兩個(gè)指針指的數(shù)字相同,則快指針向前走一步,如果不同,則兩個(gè)指針都向前走一步,這樣當(dāng)快指針走完整個(gè)數(shù)組后,慢指針當(dāng)前的坐標(biāo)加1就是數(shù)組中不同數(shù)字的個(gè)數(shù),代碼如下:

解法一:

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        int pre = 0, cur = 0, n = nums.size();
        while (cur < n) {
            if (nums[pre] == nums[cur]) ++cur;
            else nums[++pre] = nums[cur++];
        }
        return nums.empty() ? 0 : (pre + 1);
    }
};

我們也可以用 for 循環(huán)來寫,這里的j就是上面解法中的 pre,i就是 cur,所以本質(zhì)上都是一樣的,參見代碼如下:

解法二:

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        int j = 0, n = nums.size();
        for (int i = 0; i < n; ++i) {
            if (nums[i] != nums[j]) nums[++j] = nums[i];
        }
        return nums.empty() ? 0 : (j + 1);
    }
};

這里也可以換一種寫法,用變量i表示當(dāng)前覆蓋到到位置,由于不能有重復(fù)數(shù)字,則只需要用當(dāng)前數(shù)字 num 跟上一個(gè)覆蓋到到數(shù)字 nums[i-1] 做個(gè)比較,只要 num 大,則一定不會有重復(fù)(前提是數(shù)組必須有序),參見代碼如下:

解法三:

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        int i = 0;
        for (int num : nums) {
            if (i < 1 || num > nums[i - 1]) {
                nums[i++] = num;
            }
        }
        return i;
    }
};

到此,關(guān)于“C++有序數(shù)組中怎么去除重復(fù)項(xiàng)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

網(wǎng)頁題目:C++有序數(shù)組中怎么去除重復(fù)項(xiàng)
標(biāo)題URL:http://chinadenli.net/article18/iegjgp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站營銷、品牌網(wǎng)站建設(shè)、域名注冊、云服務(wù)器、微信公眾號

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
欧美日韩精品综合一区| 麻豆国产精品一区二区三区| 欧美乱码精品一区二区三| 国产亚洲中文日韩欧美综合网| 亚洲精品国产福利在线| 国产av一区二区三区四区五区| 五月婷婷缴情七月丁香| 日韩av生活片一区二区三区| 精品一区二区三区三级视频| 国产在线一区二区免费| 久久99青青精品免费观看| 日韩精品一区二区三区含羞含羞草| 国产av大片一区二区三区 | 嫩呦国产一区二区三区av| 国产又色又爽又黄的精品视频| 欧美一区二区不卡专区| 暴力三级a特黄在线观看| 国产av一区二区三区麻豆| 91人妻人人揉人人澡人| 亚洲精品中文字幕一二三| 欧美一区日韩二区亚洲三区| 日韩aa一区二区三区| 日本久久精品在线观看| 亚洲天堂有码中文字幕视频| 有坂深雪中文字幕亚洲中文| 精品人妻av区波多野结依| 成人免费高清在线一区二区| 日本欧美一区二区三区在线播| 亚洲专区中文字幕视频| 亚洲天堂精品在线视频| 美女被后入视频在线观看| 日木乱偷人妻中文字幕在线| 国产精品一区二区三区日韩av| 欧美黑人暴力猛交精品| 黄片在线免费看日韩欧美| 99久久精品午夜一区| 中文字幕亚洲精品在线播放| 男人和女人草逼免费视频| 国产中文字幕一二三区| 色小姐干香蕉在线综合网| 黄片美女在线免费观看|