国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

【算法學(xué)習(xí)】1486. 數(shù)組異或操作(java / c / c++ / python / go /

ztyzz / 2142人閱讀

摘要:數(shù)組定義為下標(biāo)從開始且。請返回中所有元素按位異或后得到的結(jié)果。樣例輸入輸出解釋數(shù)組為,其中。為按位異或運(yùn)算符。也就是只有是奇數(shù)并且是奇數(shù)的時(shí)候,最終結(jié)果的最低位才會(huì)是。

非常感謝你閱讀本文~
歡迎【?點(diǎn)贊】【?收藏】【?評(píng)論】~
放棄不難,但堅(jiān)持一定很酷~
希望我們大家都能每天進(jìn)步一點(diǎn)點(diǎn)~
本文由 二當(dāng)家的白帽子 https://le-yi.blog.csdn.net/ 博客原創(chuàng)~



1486. 數(shù)組異或操作:

給你兩個(gè)整數(shù),n 和 start 。

數(shù)組 nums 定義為:nums[i] = start + 2 * i(下標(biāo)從 0 開始)且 n == nums.length 。

請返回 nums 中所有元素按位異或(XOR)后得到的結(jié)果。

樣例 1

輸入:	n = 5, start = 0輸出:	8解釋:	數(shù)組 nums 為 [0, 2, 4, 6, 8],其中 (0 ^ 2 ^ 4 ^ 6 ^ 8) = 8 。     "^" 為按位異或 XOR 運(yùn)算符。

樣例 2

輸入:	n = 4, start = 3輸出:	8解釋:	數(shù)組 nums 為 [3, 5, 7, 9],其中 (3 ^ 5 ^ 7 ^ 9) = 8.

樣例 3

輸入:	n = 1, start = 7輸出:	7

樣例 4

輸入:	n = 10, start = 5輸出:	2

提示

  • 1 <= n <= 1000
  • 0 <= start <= 1000
  • n == nums.length

分析

我們可以直接按照題意,暴力循環(huán),那么時(shí)間復(fù)雜度就是O(n),是否有時(shí)間復(fù)雜度為O(1)的算法呢?

記x為變量,^是異或操作,則異或運(yùn)算滿足以下性質(zhì):

  1. x ^ x = 0;
  2. x ^ 0 = x;
  3. x ^ y = y ^ x(交換律);
  4. (x ^ y) ^ z = x ^ (y ^ z)(結(jié)合律);
  5. x ^ y ^ y = x(自反性);
  6. 如果x是4的倍數(shù),x ^ (x + 1) ^ (x + 2) ^ (x + 3) = 0;
  • 本題要計(jì)算的 結(jié)果公式 為:start ^ (start + 2) ^ (start + 4) ^ ? ^(start + 2 * (n ? 1))
  • 如果有一個(gè)函數(shù) sumXor(x) 可以計(jì)算 0 ^ 1 ^ 2 ^ ? ^ x
  • 對(duì)于某變量x和n,計(jì)算sumXor(s - 1) ^ sumXor(s + n - 1)的結(jié)果,根據(jù)上面的 性質(zhì)1 可以將 0 ^ 1 ^ 2 ^ … ^ (s - 1) 的值抵消為0,就變成 0 ^ s ^ (s + 1) ^ (s + 2) ^ ? ^ (s + n - 1) ,根據(jù) 性質(zhì)2 可知與0做異或操作還是自己,最后結(jié)果就變成 s ^ (s + 1) ^ (s + 2) ^ ? ^ (s + n - 1) ,這個(gè)結(jié)果很接近我們要計(jì)算的內(nèi)容。
  • 如果我們令 s = start / 2 ,把 結(jié)果公式 轉(zhuǎn)換成 (s ^ (s + 1) ^ (s + 2) ^ ? ^ (s + n - 1)) * 2,這樣并不成立,因?yàn)樵谧龀?的操作時(shí),最低位丟失了,但是我們可以多帶帶處理最低位。
  • 觀察 結(jié)果公式 可知 (start + 2),(start + 4) ,… ,(start + 2 * (n ? 1)) 的奇偶性質(zhì)相同,而且和start一致,也就是最低位要么都是0,要么都是1,只有基數(shù)個(gè)1做異或操作時(shí)才會(huì)是1。也就是只有start是奇數(shù)并且n是奇數(shù)的時(shí)候,最終結(jié)果的最低位 e 才會(huì)是1。
  • 這時(shí) 結(jié)果公式 可以轉(zhuǎn)化為: ((sumXor(s - 1) ^ sumXor(s + n - 1)) * 2) | e

只要我們可以實(shí)現(xiàn)函數(shù)sumXor(x),那么題目計(jì)算就可以做到O(1)的時(shí)間復(fù)雜度,根據(jù) 性質(zhì)6性質(zhì)2 我們只需要考慮x除以4的余數(shù),也就是最低2位,可以得到如下推導(dǎo):

x % 4 = 0 的二進(jìn)制位:xx…x00
x % 4 = 1 的二進(jìn)制位:xx…x01
x % 4 = 2 的二進(jìn)制位:xx…x10
x % 4 = 3 的二進(jìn)制位:xx…x11

  • x % 4 = 0,sumXor(x) = x;
  • x % 4 = 1,sumXor(x) = (x - 1) ^ x,簡化可得 sumXor(x) = 1;
  • x % 4 = 2,sumXor(x) = (x - 2) ^ (x - 1) ^ x,簡化可得 sumXor(x) = x | 1;
  • x % 4 = 3,sumXor(x) = 0;
  • x % 4 等同于 x & 3 的操作,而且理論上 & 操作要比 % 操作更快;

題解

java

class Solution {    public int xorOperation(int n, int start) {        int s = start >> 1, e = n & start & 1;        int ret = sumXor(s - 1) ^ sumXor(s + n - 1);        return ret << 1 | e;    }    public int sumXor(int x) {        switch (x & 3) {            case 0:                return x;            case 1:                return 1;            case 2:                return x | 1;            default:                // x & 3 == 3                return 0;        }    }}

c

int xorOperation(int n, int start) {    int s = start >> 1, e = n & start & 1;    int ret = sumXor(s - 1) ^ sumXor(s + n - 1);    return ret << 1 | e;}int sumXor(int x) {    switch (x & 3) {        case 0:            return x;        case 1:            return 1;        case 2:            return x | 1;        default:            // x & 3 == 3            return 0;    }}

c++

class Solution {public:    int xorOperation(int n, int start) {        int s = start >> 1, e = n & start & 1;        int ret = sumXor(s - 1) ^ sumXor(s + n - 1);        return ret << 1 | e;    }    int sumXor(int x) {        switch (x & 3) {            case 0:                return x;            case 1:                return 1;            case 2:                return x | 1;            default:                // x & 3 == 3                return 0;        }    }};

python

class Solution:    def xorOperation(self, n: int, start: int) -> int:        def sumXor(x):            if x % 4 == 0:                return x            if x % 4 == 1:                return 1            if x % 4 == 2:                return x | 1            return 0        s = start >> 1        e = n & start & 1        ans = sumXor(s - 1) ^ sumXor(s + n - 1)        return ans << 1 | e

go

func xorOperation(n, start int) (ans int) {    s, e := start>>1, n&start&1    ret := sumXor(s-1) ^ sumXor(s+n-1)    return ret<<1 | e}func sumXor(x int) int {    switch x & 3 {        case 0:            return x        case 1:            return 1        case 2:            return x | 1        default:            return 0    }}

rust

impl Solution {   pub fn xor_operation(n: i32, start: i32) -> i32 {    let s = start >> 1;    let e = n & start & 1;    let ret = Solution::sum_xor(s - 1) ^ Solution::sum_xor(s + n - 1);    return ret << 1 | e  }  fn sum_xor(x: i32) -> i32 {    match x & 3 {      0 => x,      1 => 1,      2 => x | 1,      _ => 0    }  }}


原題傳送門


文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/122565.html

相關(guān)文章

  • 算法學(xué)習(xí)】1920. 基于排列構(gòu)建數(shù)組java / c / c++ / python / go

    摘要:請你構(gòu)建一個(gè)同樣長度的數(shù)組,其中,對(duì)于每個(gè),都滿足。返回構(gòu)建好的數(shù)組。從開始的排列是一個(gè)由到和也包含在內(nèi)的不同整數(shù)組成的數(shù)組。 非常感謝你閱讀本文,歡迎【?點(diǎn)贊...

    aisuhua 評(píng)論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.40 - 2018,來學(xué)習(xí)一門新的編程語言吧!

    摘要:入門,第一個(gè)這是一門很新的語言,年前后正式公布,算起來是比較年輕的編程語言了,更重要的是它是面向程序員的函數(shù)式編程語言,它的代碼運(yùn)行在之上。它通過編輯類工具,帶來了先進(jìn)的編輯體驗(yàn),增強(qiáng)了語言服務(wù)。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不覺已經(jīng)到來了,總結(jié)過去的 2017,相信小伙們一定有很多收獲...

    caspar 評(píng)論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.40 - 2018,來學(xué)習(xí)一門新的編程語言吧!

    摘要:入門,第一個(gè)這是一門很新的語言,年前后正式公布,算起來是比較年輕的編程語言了,更重要的是它是面向程序員的函數(shù)式編程語言,它的代碼運(yùn)行在之上。它通過編輯類工具,帶來了先進(jìn)的編輯體驗(yàn),增強(qiáng)了語言服務(wù)。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不覺已經(jīng)到來了,總結(jié)過去的 2017,相信小伙們一定有很多收獲...

    nihao 評(píng)論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.40 - 2018,來學(xué)習(xí)一門新的編程語言吧!

    摘要:入門,第一個(gè)這是一門很新的語言,年前后正式公布,算起來是比較年輕的編程語言了,更重要的是它是面向程序員的函數(shù)式編程語言,它的代碼運(yùn)行在之上。它通過編輯類工具,帶來了先進(jìn)的編輯體驗(yàn),增強(qiáng)了語言服務(wù)。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不覺已經(jīng)到來了,總結(jié)過去的 2017,相信小伙們一定有很多收獲...

    Drummor 評(píng)論0 收藏0
  • 算法日積月累】1-選擇排序

    摘要:選擇排序算法實(shí)現(xiàn)實(shí)現(xiàn)選擇排序,記錄最小元素的索引,最后才交換位置說明交換兩個(gè)數(shù)組中的元素,在中有更簡單的寫法,這是的語法糖,其它語言中是沒有的。和語言中比較器的實(shí)現(xiàn)前面我們說到了,我們?yōu)榱送怀雠判蛩惴ǖ乃枷耄瑢⑺械睦觾H限在數(shù)組排序中。 showImg(https://segmentfault.com/img/remote/1460000017909538?w=1949&h=1080...

    neuSnail 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<