16.8.18网易内推笔试题(二)——混合颜料 详解

这道题的地址网页内推笔试题(二)——混合颜料

题目如下:

屏幕快照 2016-08-18 16.06.59.png

<u>题目翻译理解</u>

ok,这道题翻译过来,就是进行多次输入,每次输入n个数,将这些数之间进行多次xor(异或操作),其中一个数可能被xor多次,看最后能剩余多少不重复的数,输出数量即可。

<u>解题思路</u>

在C++中,将两个数进行xor,用的是^符号,但是实际上是将十进制转换为二进制之后,再进行xor,这样,这n个十进制的数,就被转换成了n个二进制的包含1,0的字符串,将每个数转换成二进制之后单成一行,位数小的前面被补全0,这样这n个数就变成了n行矩阵,由于1 ≤ xi ≤ 1,000,000,000,而2的30次幂是10亿多,所以这个矩阵最大是n*30的矩阵。

现在将这个矩阵列出来,如:

101010
111010
101101
110110

然后进行行与行之间的xor,其中1^1=0; 0^0=0; 1^0=1; 0^1=1;
有没有发现这种运算很像求矩阵的秩?相同的相减为0,不同的相减为1.

矩阵的秩定义:是其行向量或列向量的极大无关组中包含向量的个数。
矩阵的秩求法:用初等行变换化成梯矩阵, 梯矩阵中非零行数就是矩阵的秩.

所以这道题就被转化成了求矩阵的秩, 求法如下。

//
//  main.cpp
//  NiuKe_HunHeYanLiao
//
//  Created by 麦心 on 16/8/18.
//  Copyright © 2016年 程序工匠0_0小姐. All rights reserved.
//

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

//求一个数的二进制的最高位是哪位
int getHighBit(int num){
    int highbit = 0;
    while (num) {
        //将该数的二进制右移一位
        num>>=1;
        highbit++;
    }
    return highbit;
}

int main() {
    vector<int> colors;
    int n;
    
    while(cin >> n){
        colors.clear();
        int result = 0;
        int temp;
        int i = n;
        while (i--) {
            cin>>temp;
            colors.push_back(temp);
        }
        
        //将colors进行从小到大的排序
        sort(colors.begin(), colors.end());
        int bigger, smaller;
        //bigger和smaller始终指向的是最后一位和倒数第二位数
        bigger = n - 1;
        smaller = bigger - 1;
        
        while (colors.size()>2) {
            //如果两者的最高位相同,说明最高位可以消掉,
            //将两者xor,或者说将矩阵两行相减消掉最高位
            if(getHighBit(colors[bigger]) == getHighBit(colors[smaller])){
                int tem = colors[bigger]^colors[smaller];
                //find函数头文件是<algorithm>
                //泛型算法的 find,在非string类型的容器里,可以直接找出所对应的元素
                //从vector的头开始一直到尾,找到第一个值为temp的元素,返回的是一个指向该元素的迭代器std::vector<int>::iterator类型
                
                //因为现在xor的是两个最大的数,而且最高位已被消掉,所以xor得到的结果一定比这两个数小  
                //如果temp这个 比最大两个数小的 数没有被找到,则将temp加到colors数组中,进行再次xor
                //找不到的话,返回colors.end应该是固定用法
                if(find(colors.begin(), colors.end(), tem)==colors.end()){
                    colors.push_back(tem);
                    sort(colors.begin(), colors.end());
                    bigger++;//因为colors中多了一个数,所以需要位数+1
                    smaller++;
                }
            }else{
                result++;
            }

            //如果两者最高位不同,说明已经所有数的最高位已经只有最大的那个数是1了,这样它已经不可能被消掉了,结果+1
            
            //如果两个最大数的最高位可以消掉,那么消除之后,最大数已被消掉,没有用了
            //如果两个最大数的最高位不可以消掉,那么结果+1,最大数也没有用了。
            //弹出最大数
            colors.pop_back();
            
            //因为弹出了一个数,所以bigger和smaller都要相应-1
            bigger = smaller;
            smaller--;
        }
        cout<<result+colors.size()<<endl;
    }
}

提交,用例全部通过。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容