食物鏈POJ1182總結(jié)

這道題是用并查集來解例获。并查集可以高效的查找某個元素是否屬于一個集合。
敲代碼過程中一次遇到了如下問題:

new 的使用問題

想開辟一塊放100個整形變量的空間范抓,我這樣寫的:

 int *father = new  int(100);

給這個int數(shù)組賦值的時候一直報錯冯丙,覺得自己一定是開辟空間的時候搞錯了。
果然咖熟,new A(100)的寫法是說,把變量的值初始化成100柳畔。
想要開辟100個A類型的變量空間馍管,應(yīng)該這么寫:

int *father=new int[100];

按照《挑戰(zhàn)程序設(shè)計競賽》思路寫出的代碼超時

我在看這邊書的時候就一直有一個疑問,作者是不是由于原先寫慣了C語言薪韩,C++里面的cin和cout用著不順手确沸,所以還特別費事兒的加上#include<cstdio>的頭文件,并且輸入輸出用printf和scanf躬存。
今天我按照這本書的思路寫了1182這一題张惹,發(fā)現(xiàn)一直超時,把cin改成scanf就AC了岭洲,百度了一下發(fā)現(xiàn)很多文章討論它倆性能的差異宛逗。得出的結(jié)論是,程序設(shè)計題盡量用scanf而不是cin盾剩。

源代碼

#include <iostream>
#include <cstdio>
using namespace std;

class union_find
{
private:
        int* father;
        int* height;
        int n;
public:
    union_find(int n)
    {

        this->n = n;

        father = new int[n];

        height = new int[n];
        for(int i=0;i<n;i++)
        {

            father[i]=i;
            height[i]=0;
        }

    }
    ~union_find()
    {
        delete []father;
        delete []height;
    }
    int _find(int x)
    {
        if(x>=n)
        {

            return 0;
        }
        if(father[x]==x)
        {
            return x;
        }
        else
        {
            return father[x]=(_find(father[x]));
        }
    }
    void unite(int x,int y)
    {
        if(x>=n||y>=n)
        {

            return;
        }
        x = _find(x);
        y = _find(y);
        if(height[x]<height[y])
        {
            father[x]=y;
        }
        else
        {
            father[y]=x;
            if(height[x]==height[y])
            {
                height[x]++;
            }
        }
    }

    bool same(int x,int y)
    {
        return _find(x) == _find(y);
    }

};



int main()
{
    int n,k;
    scanf("%d%d",&n,&k);
   // cin>>n>>k;


    union_find f(n*3);

    int ans=0;

    for(int i=0;i<k;i++)
    {
        int t,x,y;
        //cin>>t>>x>>y;
        scanf("%d%d%d",&t,&x,&y);

        x = x-1;
        y = y-1;

        if(x<0||x>=n||y<0||y>=n)
        {

            ans++;
            continue;
        }
        if(t==1)
        {
            if(f.same(x,y+n)||f.same(x,y+2*n))
            {

                ans++;
                continue;
            }
            else
            {
                f.unite(x,y);
                f.unite(x+n,y+n);
                f.unite(x+2*n,y+2*n);
            }
        }
        else
        {
            if(f.same(x,y)||f.same(y,x+n))
            {
                ans++;
                continue;
            }
            else
            {
                f.unite(x,y+n);
                f.unite(x+n,y+2*n);
                f.unite(x+2*n,y);
            }
        }
    }
    cout<<ans<<endl;
    return ans;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末雷激,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子告私,更是在濱河造成了極大的恐慌屎暇,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驻粟,死亡現(xiàn)場離奇詭異根悼,居然都是意外死亡,警方通過查閱死者的電腦和手機蜀撑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門挤巡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人酷麦,你說我怎么就攤上這事矿卑。” “怎么了沃饶?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵母廷,是天一觀的道長。 經(jīng)常有香客問我糊肤,道長琴昆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任轩褐,我火速辦了婚禮椎咧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己勤讽,他們只是感情好蟋座,可當(dāng)我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著脚牍,像睡著了一般向臀。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上诸狭,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天券膀,我揣著相機與錄音,去河邊找鬼驯遇。 笑死芹彬,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叉庐。 我是一名探鬼主播舒帮,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼陡叠!你這毒婦竟也來了玩郊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤枉阵,失蹤者是張志新(化名)和其女友劉穎译红,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兴溜,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡侦厚,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了拙徽。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片假夺。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖斋攀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情梧田,我是刑警寧澤淳蔼,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站裁眯,受9級特大地震影響鹉梨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜穿稳,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一存皂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦旦袋、人聲如沸骤菠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽商乎。三九已至,卻和暖如春祭阀,著一層夾襖步出監(jiān)牢的瞬間鹉戚,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工专控, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留抹凳,地道東北人。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓伦腐,卻偏偏與公主長得像赢底,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蔗牡,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,871評論 2 354

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,117評論 25 707
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法颖系,類相關(guān)的語法,內(nèi)部類的語法辩越,繼承相關(guān)的語法嘁扼,異常的語法,線程的語...
    子非魚_t_閱讀 31,631評論 18 399
  • 時間過得真快一眨眼20年過去了我已經(jīng)從一個小學(xué)生變成了一名醫(yī)生這次休年假我打算回我的家鄉(xiāng)威海去看看我坐上了飛機踏上...
    越越1閱讀 363評論 0 0
  • 帶著開學(xué)前期綜合癥開工了黔攒,早上在幾位老師的幫助下趁啸,整理了教導(dǎo)處堆積如山的檔案資料,辦公室總算是清爽了督惰,接下...
    方圓_22cf閱讀 177評論 0 1
  • 花開幾度芳菲盡不傅,葉落無聲韶華歇。 人生百年夢一場赏胚,黃土塵沙掩白骨访娶。
    綰綰不乖閱讀 266評論 1 2