UVa253 - Cube painting

題目

題目意思是每行輸入兩個篩子蚊夫,然后判斷兩個篩子的是不是用了相同的噴涂方式券时,即兩個篩子是否為同一個(忽略數(shù)字)邮旷。每個篩子最多有三種顏色r黄选、g、b婶肩。每行輸入12個字符不含空格办陷。

我們可以想想,如果我們?nèi)藖聿僮魇窃趺礃幼龅模?br> 第一步是把同色的一面對著自己律歼。(此時視為頂部民镜,編號1)
第二步是看底部是否同色。(底部編號6)
第三步是看能否通過水平旋轉(zhuǎn)使得完全相同险毁。

想清楚之后就可以敲代碼了制圈。值得注意的是輸入的處理,筆者這里用了一個函數(shù)read()來讀入畔况,也增加一點抗性鲸鹦。還有使用string里面的函數(shù)時要確保字符串有結(jié)束符。

代碼

#include <stdio.h>
#include <string.h>

const int maxn = 6;

char c1[maxn + 2], c2[maxn + 2], ct[maxn + 2];

int read();
void find(char s[], char aid, int index[]);
void turn(char s[], int i);
void turnH(char s[]);
void turnV(char s[]);

int main() {
#ifdef TEST
    freopen("test.in", "r", stdin);
    freopen("test.out", "w", stdout);
#endif // TEST
    while (read()) {
        int flag = 0;
        int index[maxn + 2];
        find(c1, c2[1], index);
        for (int i = 0; i < 6 && index[i]; i++) {
            strcpy(ct, c1); turn(ct, index[i]);
            if (ct[6] != c2[6]) continue;
            for (int j = 0; j < 4 && strcmp(ct, c2); j++) turnH(ct);
            if (!strcmp(ct, c2)) flag = 1;
        }
        if (flag) printf("TRUE\n");
        else printf("FALSE\n");
    }
    return 0;
}

int read(){
    //因為會用到大量的string里的函數(shù)跷跪,所以需要確保有結(jié)束符馋嗜。
    memset(c1, ' ', sizeof(c1)); c1[7] = '\0';
    memset(c2, ' ', sizeof(c2)); c2[7] = '\0';
    char ch = getchar(); 
    //最有可能讀到的不想要的字符就是這兩個
    while (ch == '\n' || ch == ' ') ch = getchar();  
    if (ch == EOF) return 0;
    c1[1] = ch;
    for (int i = 2; i <= maxn; i++) c1[i] = getchar();
    for (int i = 1; i <= maxn; i++) c2[i] = getchar();
    return 1;
}

void find(char s[], char aid, int index[]){
    memset(index, 0, sizeof(index));
    for (int i = 1, n = 0; i <= 6; i++)
        if (s[i] == aid) index[n++] = i;
}

void turn(char s[], int i){
    switch (i)
    {
    case 2:
        turnV(s); turnV(s); turnV(s); break;
    case 3:
        turnH(s); turnH(s); turnH(s); turnV(s); break;
    case 4:
        turnH(s); turnV(s); break;
    case 5:
        turnV(s); break;
    case 6:
        turnV(s); turnV(s); break;
    default:
        break;
    }
}
//從上往下看逆時針,1在頂
void turnH(char s[]){
    char t = s[2];
    s[2] = s[3];
    s[3] = s[5];
    s[5] = s[4];
    s[4] = t;
}
//從右往左看逆時針域庇,1在頂嵌戈,2在前
void turnV(char s[]) {
    char t = s[1];
    s[1] = s[5];
    s[5] = s[6];
    s[6] = s[2];
    s[2] = t;
}

原題

UVa253
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末覆积,一起剝皮案震驚了整個濱河市听皿,隨后出現(xiàn)的幾起案子熟呛,更是在濱河造成了極大的恐慌,老刑警劉巖尉姨,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件庵朝,死亡現(xiàn)場離奇詭異,居然都是意外死亡又厉,警方通過查閱死者的電腦和手機(jī)九府,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來覆致,“玉大人侄旬,你說我怎么就攤上這事』吐瑁” “怎么了儡羔?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長璧诵。 經(jīng)常有香客問我汰蜘,道長,這世上最難降的妖魔是什么之宿? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任族操,我火速辦了婚禮,結(jié)果婚禮上比被,老公的妹妹穿的比我還像新娘色难。我一直安慰自己,他們只是感情好等缀,可當(dāng)我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布枷莉。 她就那樣靜靜地躺著,像睡著了一般项滑。 火紅的嫁衣襯著肌膚如雪依沮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天枪狂,我揣著相機(jī)與錄音危喉,去河邊找鬼。 笑死州疾,一個胖子當(dāng)著我的面吹牛辜限,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播严蓖,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼薄嫡,長吁一口氣:“原來是場噩夢啊……” “哼氧急!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起毫深,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤吩坝,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后哑蔫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钉寝,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有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
  • 我被黑心中介騙來泰國打工挪哄, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人琉闪。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓迹炼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子斯入,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,691評論 2 361

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

  • 官網(wǎng) 中文版本 好的網(wǎng)站 Content-type: text/htmlBASH Section: User ...
    不排版閱讀 4,407評論 0 5
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,113評論 1 32
  • 一砂碉、Python簡介和環(huán)境搭建以及pip的安裝 4課時實驗課主要內(nèi)容 【Python簡介】: Python 是一個...
    _小老虎_閱讀 5,750評論 0 10
  • ??引用類型的值(對象)是引用類型的一個實例增蹭。 ??在 ECMAscript 中,引用類型是一種數(shù)據(jù)結(jié)構(gòu)闹伪,用于將數(shù)...
    霜天曉閱讀 1,066評論 0 1
  • 這些天在微信群里認(rèn)識了不少文友偏瓤,看到好多人的堅持努力,對比一下自己椰憋,實在讓人汗顏厅克。看著一些原本很平凡的文友橙依,因為堅...
    田筱薇閱讀 272評論 3 6