UVa1592 - Database

題目

輸入一個n行m列的數(shù)據(jù)庫(內(nèi)容為字符串)伊履,要求判斷該數(shù)據(jù)庫是否滿足條件:存在列 c1 和 c2,行 r1 和 r2扣唱,使得(r1藕坯,c1)和(r2,c1)相同噪沙,(r1炼彪,c2)和(r2,c2)相同正歼。
滿足則輸出三行:

NO
r1 r2
c1 c2

且前者比后者小
否則輸出:YES

題解

直接枚舉的話參數(shù)有四個辐马,相當不現(xiàn)實。所以考慮遍歷兩個列局义,并且掃描行喜爷。掃描時用map進行儲存,將此時列的元素組成二元組(pair)萄唇,并且映射(map)為當前行檩帐。當遇到相同的 pair 之后輸出。
還有一個技巧穷绵,就是將數(shù)據(jù)庫讀入的時候轿塔,轉(zhuǎn)換為ID,一種字符串對應(yīng)唯一ID。這個技巧核心在于對 map(str轉(zhuǎn)ID) 和 vector(ID轉(zhuǎn)str) 的綜合運用勾缭,對于以后同樣對大量字符串進行處理的時候可以用同樣的技巧揍障,因為對字符串的運算(比較)是相當慢的(當然不止只有字符串可以使用)。

代碼

#include <cstdio>
#include <map>
#include <vector>
#include <set>

using namespace std;
vector<string> Strcache; //ID轉(zhuǎn)string
map<string, int> IDcache; //string轉(zhuǎn)ID

void read(vector<int> base[], int n, int m) {
    for (int i = 1; i <= 10; i++) base[i].clear(); //清空俩由,這是好習(xí)慣
    getchar(); //丟掉上一行的 '\n'
    for (int r = 1; r <= n; r++) for (int c = 1; c <= m; c++) {
                //讀入字符串
        string s = ""; char ch;
        while ((ch = getchar()) != ',' && ch != '\n') s += ch; 
                //轉(zhuǎn)換為ID毒嫡,存入數(shù)據(jù)庫中
        if (!IDcache.count(s)) {
            Strcache.push_back(s);
            IDcache[s] = (int)Strcache.size() - 1;
        }
        base[c].push_back(IDcache[s]);
    }
}
//寫在函數(shù)里方便跳出
void check(vector<int> base[], int n, int m) {
        //i 和 j 遍歷列
    for (int i = 1; i <= m; i++) for (int j = i + 1; j <= m; j++) {
        map<pair<int, int>, int> mark;
                //掃描行
        for (int r = 0; r < base[i].size(); r++) {
            pair<int, int> p(base[i][r], base[j][r]);  //生成二元組
            if (!mark.count(p)) mark[p] = r;
            else {
                printf("NO\n");
                printf("%d %d\n", mark[p]+1, r+1);
                printf("%d %d\n", i, j);
                return;
            }
        }
    }
    printf("YES\n");
}

int main() {
    int n, m;
    while (scanf("%d%d", &n, &m) == 2 && n) {
        vector<int> base[12]; // 10cols
        IDcache.clear(); Strcache.clear();
        read(base, n, m);
        check(base, n, m);
    }
    return 0;
}

原題

UVa1592
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市幻梯,隨后出現(xiàn)的幾起案子兜畸,更是在濱河造成了極大的恐慌,老刑警劉巖碘梢,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咬摇,死亡現(xiàn)場離奇詭異,居然都是意外死亡煞躬,警方通過查閱死者的電腦和手機肛鹏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來恩沛,“玉大人在扰,你說我怎么就攤上這事±卓停” “怎么了芒珠?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長搅裙。 經(jīng)常有香客問我皱卓,道長,這世上最難降的妖魔是什么部逮? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任好爬,我火速辦了婚禮,結(jié)果婚禮上甥啄,老公的妹妹穿的比我還像新娘。我一直安慰自己炬搭,他們只是感情好蜈漓,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著宫盔,像睡著了一般融虽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上灼芭,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天有额,我揣著相機與錄音,去河邊找鬼。 笑死巍佑,一個胖子當著我的面吹牛茴迁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播萤衰,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼堕义,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了脆栋?” 一聲冷哼從身側(cè)響起倦卖,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎椿争,沒想到半個月后怕膛,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡秦踪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年褐捻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片洋侨。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡舍扰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出希坚,到底是詐尸還是另有隱情边苹,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布裁僧,位于F島的核電站个束,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏聊疲。R本人自食惡果不足惜茬底,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望获洲。 院中可真熱鬧阱表,春花似錦、人聲如沸贡珊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽门岔。三九已至爱致,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寒随,已是汗流浹背糠悯。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工帮坚, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人互艾。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓试和,卻偏偏與公主長得像,于是被迫代替她去往敵國和親忘朝。 傳聞我的和親對象是個殘疾皇子灰署,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

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