V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
firemiles
V2EX  ›  问与答

Leetcode 上一道简单题的效率问题

  •  
  •   firemiles · 2015-11-05 14:36:35 +08:00 · 2673 次点击
    这是一个创建于 3307 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Single Number

    Given an array of integers, every element appears twice except for one. Find that single one.

    Note:
    Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?

    Subscribe to see which companies asked this question

    class Solution {
    public:
        int singleNumber(vector<int>& nums) {
            int ret = 0;
             for(int i:nums) {
                 ret ^= i;
             }
             return ret;
        }
    };
    

    上 leetcode 做了一道题,怎么也想不明白为什么这个写法效率这么低,效率最高的那部分代码要怎么写才能达到?

    第 1 条附言  ·  2015-11-05 15:35:46 +08:00
    7 条回复    2015-11-05 22:03:53 +08:00
    msg7086
        1
    msg7086  
       2015-11-05 14:41:06 +08:00 via Android
    这么低?怎么低?
    iEverX
        2
    iEverX  
       2015-11-05 15:00:48 +08:00
    这是最快了吧?
    MntCw
        4
    MntCw  
       2015-11-05 15:40:26 +08:00   ❤️ 1
    int ret = nums[0]
    sleeperqp
        5
    sleeperqp  
       2015-11-05 15:53:14 +08:00   ❤️ 1
    额 你用你代码重新提交一下试试 ╭(╯^╰)╮ 有可能是 20ms 这种东西不要深究
    firemiles
        6
    firemiles  
    OP
       2015-11-05 17:20:56 +08:00
    @sleeperqp
    ```cpp
    class Solution {
    public:
    int singleNumber(vector<int>& nums) {
    int ret = nums[0];
    int len = nums.size();
    for(int i=1; i<len; ++i) {
    ret ^= nums[i];
    }
    return ret;
    }
    };
    ```
    反复提交后终于到了第一梯队,看来还是 leetcode 的测试案例太少,运行时间太少导致排名不稳定
    sleeperqp
        7
    sleeperqp  
       2015-11-05 22:03:53 +08:00
    @firemiles 也不一定 这个还可能跟运行时服务器的运行负载有关 0 0
    所以这个大概知道怎么做就最好了 除非有很大的运行时间差距
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   974 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 19:18 · PVG 03:18 · LAX 11:18 · JFK 14:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.