zoukankan      html  css  js  c++  java
  • 75 int类型数组中除了一个数出现一次或两次以外,其他数都出现三次,求这个数。[2行核心代码]

    【本文链接】

    http://www.cnblogs.com/hellogiser/p/single-number-of-array-with-other-three-times.html

    【题目】

      int类型数组中除了一个数出现一次或两次以外,其他数都出现三次,求这个数。

    【分析】

     C++ Code 
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    int singleNumber(int *a, int n)
    {
        
    int ones = 0, twos = 0;
        
    for (int i = 0; i < n; i++)
        {
            ones = (ones ^ a[i]) & (~twos);
            twos = (twos ^ a[i]) & (~ones);
        }
        
    // ones
        return ones;
    }

      当a出现一次的时候,ones能保存a。当a出现两次的时候,twos能保存a。当a出现三次的时候,ones和twos都清零。所以,如果一个数值中所有的数都通过这个循环的话,出现三次的数都清零了,有一个数如果出现一次,它保存在ones中;如果出现两次的话保存在twos中。 

    【代码】

     C++ Code 
    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
     
    // 75_OneTwoNumber_WithOther3Times.cpp : Defines the entry point for the console application.
    //
    /*
        version: 1.0
        author: hellogiser
        blog: http://www.cnblogs.com/hellogiser
        date: 2014/9/18
    */


    #include "stdafx.h"
    #include "iostream"
    using namespace std;

    void print(int *a, int n)
    {
        
    for (int i = 0; i < n; i++)
        {
            cout << a[i] << 
    " ";
        }
        cout << endl;
    }

    //==============================================================
    // single number    1,1,1,2========>2
    //==============================================================
    /*
    x 1st, ones =x, twos =0
    x 2st, ones =0, twos =x
    x 3st, ones =0, twos =0
    */

    int singleNumber(int *a, int n)
    {
        
    int ones = 0, twos = 0;
        
    for (int i = 0; i < n; i++)
        {
            ones = (ones ^ a[i]) & (~twos);
            twos = (twos ^ a[i]) & (~ones);
        }
        
    // ones
        return ones;
    }

    //==============================================================
    // double number    1,1,1,100,100========>100
    //==============================================================
    int doubleNumber(int *a, int n)
    {
        
    int ones = 0, twos = 0;
        
    for (int i = 0; i < n; i++)
        {
            ones = (ones ^ a[i]) & (~twos);
            twos = (twos ^ a[i]) & (~ones);
        }
        
    // twos
        return twos;
    }

    void test_base_single()
    {
        
    int a[] = {1112};
        
    int n = 4;
        cout << 
    "array is: ";
        print(a, n);
        cout << 
    "single number " << singleNumber(a, n) << endl;
    }

    void test_base_double()
    {
        
    int a[] = {111100100};
        
    int n = 5;
        cout << 
    "array is: ";
        print(a, n);
        cout << 
    "double number " << doubleNumber(a, n) << endl;
    }

    void test_main()
    {
        test_base_single();
        test_base_double();
    }

    int _tmain(int argc, _TCHAR *argv[])
    {
        test_main();
        
    return 0;
    }
    /*
    array is: 1 1 1 2
    single number 2
    array is: 1 1 1 100 100
    double number 100
    */

    个人学习笔记,欢迎拍砖!---by hellogiser

    Author: hellogiser
    Warning: 本文版权归作者和博客园共有,欢迎转载,但请保留此段声明,且在文章页面明显位置给出原文连接。Thanks!
    Me: 如果觉得本文对你有帮助的话,那么【推荐】给大家吧,希望今后能够为大家带来更好的技术文章!敬请【关注】
  • 相关阅读:
    ExtJs 4 的filefield上传后 返回值success接受不正常
    winform treeview 通过节点名称添加子节点
    Live Writer Test
    mysqlcluster笔记
    ExtJS中form提交之后获取返回的json值
    MYSQL大小写(由于数据由windows迁移到Linux导致)
    ORACLE分科目统计每科前三名的学生的语句
    一列数据横排显示
    Oracle11g使用exp导出空表
    myeclipse2015卸载、安装、破解全过程-----myeclipse2015
  • 原文地址:https://www.cnblogs.com/hellogiser/p/single-number-of-array-with-other-three-times.html
Copyright © 2011-2022 走看看