騰訊面試題

題目:
給你10分鐘時(shí)間腾它,根據(jù)上排給出十個(gè)數(shù)宅静,在其下排填出對應(yīng)的十個(gè)數(shù)痰催。要求下排每個(gè)數(shù)都是先前上排對應(yīng)那個(gè)數(shù)在下排十個(gè)數(shù)中出現(xiàn)的次數(shù)姻报。
舉一個(gè)例子己英,
數(shù)值: 0,1,2,3,4,5,6,7,8,9
分配: 6,2,1,0,0,0,1,0,0,0
難點(diǎn):理解題意,然后從中找出規(guī)則
思路:理解下排中的每個(gè)數(shù)都是上排對應(yīng)數(shù)字在下排的出現(xiàn)次數(shù)
假設(shè)上排a[0]~a[n-1]
下排b[0]~b[n-1]
不難看出會有如下規(guī)則:
設(shè)上排的數(shù)字用 a[i]表示, 下排的數(shù)字用b[i]表示吴旋,每排有n個(gè)數(shù)字损肛。則應(yīng)滿足條件:
① ∑b[i] = n 下排所有數(shù)字的和為n
②∑a[i]b[i] = n 上下排對應(yīng)的數(shù)字乘積相加的和為n
③ 下排出現(xiàn)了 b[i] 個(gè) a[i]
④b[i] 一定小于 n
方法是暴力查找,從全0開始 嘗試所有的0-n的數(shù)字組合
在每次選擇一個(gè)數(shù)字后荣瑟,先用∑a[i]
b[i] <= n 和 ∑b[i] <= n 的條件去掉一大部分不符合條件的 相當(dāng)于截枝 加快速度
然后對每次選定所有下排的數(shù)后治拿,驗(yàn)證是否滿足條件① 和 ③(滿足這兩個(gè)條件 其他的條件一定滿足) 滿足則返回。

#include <iostream>
using namespace std;

//檢查笆焰,已有數(shù)字加起來的和是否超過n
bool checkSum(int * b, int n)
{
    int sum = 0;
    for (int j = 0; j < n; j++)
    {
        sum += b[j];
    }
    return (sum == n) ;
}
//檢查組成是否滿足 “下排每個(gè)數(shù)都是先前上排那十個(gè)數(shù)在下排出現(xiàn)的次數(shù)劫谅。”
bool checkcomponet(int * a, int * b, int n)
{
    for (int i = 0; i < n; i++)
    {
        int num = 0;
        for (int j = 0; j < n;j++)
        {
            if (b[j] == a[i])
            {
                num++;
            }
        }
        if (num != b[i])
        {
            return false;
        }
    }
    return true;
}

/*
暴力計(jì)算
in:輸入
out:輸出數(shù)組
n:一共有多少個(gè)數(shù)字
num:當(dāng)前要確定第幾個(gè)數(shù)字
*/
bool findnum(int * in, int * out, int n, int num) 
{
    bool isFind = false;
    for (int i = 0; i < n; i++)
    {
        out[num - 1] = i; //設(shè)當(dāng)前數(shù)為i
        
        //根據(jù)和 與 積 不能大于n 去掉大部分錯(cuò)誤的嘗試 
        int product = 0;
        int sum = 0;
        for (int j = num - 1; j < n; j++)
        {
            product += out[j]*in[j];
            sum += out[j];
        }
        if (sum > n || product > n)
        {
            break;
        }


        if (num == 1)
        {
            if (checkcomponet(in, out, n) && checkSum(out, n))
            {
                isFind = true;
            }
        }
        else
        {
            isFind = findnum(in, out, n, num - 1); 
        }

        if (isFind == true)
        {
            break;
        }
        
    }
    return isFind;
}

int main()
{
    int a[11] = {0,-1,1,2,-2,3,4,5,7,8,10};
    int b[11] = {0};
    bool isfind = findnum(a,b,11,11);

    cout << "a: ";
    for (int i = 0; i < 11; i++)
    {
        cout << a[i]<< ' ';
    }
    cout<<endl;
    if (isfind == true)
    {
        cout << "b: ";
        for (int i = 0; i < 11; i++)
        {
            cout << b[i]<< ' ';
        }
        cout<<endl;
    }
    else
    {
        cout << "no answer can be find!" << endl;
    }
    return 0;
}

這種方式思路比較好理解嚷掠,但是執(zhí)行時(shí)間復(fù)雜度很高捏检,當(dāng)n很大的時(shí)候不可取。但是在網(wǎng)上沒有找到比較好的解法了不皆。
網(wǎng)上找到一個(gè)規(guī)律:如果是n個(gè)連續(xù)的從0到n-1個(gè)數(shù)字贯城,那么,1和2下面的數(shù)是2和1霹娄,0下面的數(shù)是n-3冤狡,其中n是最后一個(gè)數(shù)的下標(biāo),n-3下面是1

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末项棠,一起剝皮案震驚了整個(gè)濱河市悲雳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌香追,老刑警劉巖合瓢,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異透典,居然都是意外死亡晴楔,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進(jìn)店門峭咒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來税弃,“玉大人,你說我怎么就攤上這事凑队≡蚬” “怎么了?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長西壮。 經(jīng)常有香客問我遗增,道長,這世上最難降的妖魔是什么款青? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任做修,我火速辦了婚禮,結(jié)果婚禮上抡草,老公的妹妹穿的比我還像新娘饰及。我一直安慰自己,他們只是感情好康震,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布旋炒。 她就那樣靜靜地躺著,像睡著了一般签杈。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鼎兽,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天答姥,我揣著相機(jī)與錄音,去河邊找鬼谚咬。 笑死鹦付,一個(gè)胖子當(dāng)著我的面吹牛择卦,可吹牛的內(nèi)容都是我干的敲长。 我是一名探鬼主播秉继,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼尚辑!你這毒婦竟也來了辑鲤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤杠茬,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后瓢喉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宁赤,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡栓票,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年决左,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,747評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡哆窿,死狀恐怖链烈,靈堂內(nèi)的尸體忽然破棺而出挚躯,到底是詐尸還是另有隱情,我是刑警寧澤码荔,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站缩搅,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏硼瓣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一堂鲤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瘟栖,春花似錦、人聲如沸半哟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至戒良,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蔬墩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工奏司, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人韵洋。 一個(gè)月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像搪缨,于是被迫代替她去往敵國和親食拜。 傳聞我的和親對象是個(gè)殘疾皇子副编,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容