24h購物| | PChome| 登入
2011-06-30 23:02:32| 人氣1,054| 回應0 | 上一篇 | 下一篇

d627. 我.我.我...這麼弱 -跨年倒數

推薦 0 收藏 0 轉貼0 訂閱站台

d627. 我.我.我...這麼弱 -跨年倒數

內容 :

時間過得真快,2009年即將結束。大家都準備迎接新的一年,你能夠幫忙倒數計時嗎?
計時的方法非常簡單,使用「電算機」顯示的方法來輸出﹝請參考範例輸出﹞。
給你一個數字N(0<N<=10)來表示顯示幕的大小,接著輸入分鐘及時間m&s(0<=m<=20),(0<=s<=59),表示從何時倒數。

PS:如果你在1月1日0:00分AC本題,會有一整年的好運喔

輸入說明 :

輸入為三個數字N(0<N<=10),m(0<=m<=20),s(0<=s<=59)
N表示顯示幕的大小,接著輸入分鐘及時間m&s,表示從何時倒數。
以N=0 m=0 s=0做為結束

輸出說明 :

輸出使用「電算機」顯示的方法來輸出,其格式為"mm ss"
計時至00 00結束,並且也用「電算機」顯示的方法來輸出"HAPPY NEWYEAR"﹝HAPPY及NEWYEAR間請換行﹞。

每個數字即英文字占2*N+2列,2*N+3行,分鐘及秒之間有N個空格。
注意!輸出檔極大,請優化輸出。
請參考範例輸出

範例輸入 :

1 0 10
2 0 2
3 0 1
0 0 0

範例輸出 :

 --   --         --  
|  | |  |     | |  |
                     
|  | |  |     | |  |
 --   --         --  

 --   --    --   --  
|  | |  |  |  | |  |
                 --  
|  | |  |  |  |    |
 --   --    --   --  

 --   --    --   --  
|  | |  |  |  | |  |
                 --  
|  | |  |  |  | |  |
 --   --    --   --  

 --   --    --   --  
|  | |  |  |  |    |
                     
|  | |  |  |  |    |
 --   --    --       

 --   --    --   --  
|  | |  |  |  | |   
                 --  
|  | |  |  |  | |  |
 --   --    --   --  

 --   --    --   --  
|  | |  |  |  | |   
                 --  
|  | |  |  |  |    |
 --   --    --   --  

 --   --    --       
|  | |  |  |  | |  |
                 --  
|  | |  |  |  |    |
 --   --    --       

 --   --    --   --  
|  | |  |  |  |    |
                 --  
|  | |  |  |  |    |
 --   --    --   --  

 --   --    --   --  
|  | |  |  |  |    |
                 --  
|  | |  |  |  | |   
 --   --    --   --  

 --   --    --       
|  | |  |  |  |    |
                     
|  | |  |  |  |    |
 --   --    --       

 --   --    --   --  
|  | |  |  |  | |  |
                     
|  | |  |  |  | |  |
 --   --    --   --  

      --   --   --       
|  | |  | |  | |  | |  |
 --   --   --   --   --  
|  | |  | |    |       |
                      -  
      --             --   --   --  
|\ | |    |  | |  | |    |  | |  |
      --        --   --   --   --  
| \| |    |/\|    | |    |  | | \ 
      --         -   --            
 ----   ----     ----   ----  
|    | |    |   |    |      |
|    | |    |   |    |      |
                        ----  
|    | |    |   |    | |     
|    | |    |   |    | |     
 ----   ----     ----   ----  

 ----   ----     ----         
|    | |    |   |    |      |
|    | |    |   |    |      |
                              
|    | |    |   |    |      |
|    | |    |   |    |      |
 ----   ----     ----         

 ----   ----     ----   ----  
|    | |    |   |    | |    |
|    | |    |   |    | |    |
                              
|    | |    |   |    | |    |
|    | |    |   |    | |    |
 ----   ----     ----   ----  

        ----   ----   ----         
|    | |    | |    | |    | |    |
|    | |    | |    | |    | |    |
 ----   ----   ----   ----   ----  
|    | |    | |      |           |
|    | |    | |      |           |
                               --  
        ----                 ----   ----   ----  
|\   | |      |    | |    | |      |    | |    |
| \  | |      |    | |    | |      |    | |    |
        ----          ----   ----   ----   ----  
|  \ | |      | /\ |      | |      |    | |  \  
|   \| |      |/  \|      | |      |    | |   \ 
        ----            --   ----                
 ------   ------      ------           
|      | |      |    |      |        |
|      | |      |    |      |        |
|      | |      |    |      |        |
                                       
|      | |      |    |      |        |
|      | |      |    |      |        |
|      | |      |    |      |        |
 ------   ------      ------           

 ------   ------      ------   ------  
|      | |      |    |      | |      |
|      | |      |    |      | |      |
|      | |      |    |      | |      |
                                       
|      | |      |    |      | |      |
|      | |      |    |      | |      |
|      | |      |    |      | |      |
 ------   ------      ------   ------  

          ------   ------   ------           
|      | |      | |      | |      | |      |
|      | |      | |      | |      | |      |
|      | |      | |      | |      | |      |
 ------   ------   ------   ------   ------  
|      | |      | |        |               |
|      | |      | |        |               |
|      | |      | |        |               |
                                        ---  
          ------                     ------   ------   ------  
|\     | |        |      | |      | |        |      | |      |
| \    | |        |      | |      | |        |      | |      |
|  \   | |        |      | |      | |        |      | |      |
          ------            ------   ------   ------   ------  
|   \  | |        |  /\  |        | |        |      | |   \   
|    \ | |        | /  \ |        | |        |      | |    \  
|     \| |        |/    \|        | |        |      | |     \ 
          ------               ---   ------                    

提示 :

出處 :

ACM強化 c135. LC-Display (管理:genius0615)



作法 : 模擬
沒想到我code長度最短,好害羞啊 >///<
尤其是英文的部分最難處理

/**********************************************************************************/

/*  Problem: d627 "我.我.我...這麼弱   -跨年倒數" from ACM強化   c135. LC-Display*/
/*  Language: C                                                                   */
/*  Result: AC (29ms, 280KB) on ZeroJudge                                         */
/*  Author: morris1028 at 2011-06-30 22:54:59                                     */
/**********************************************************************************/


#include<stdio.h>
char type[10][6] = {
    {"    "},{"   |"},{"|   "},{"|  |"},{" -- "},
    {"|\\ |"},{"| \\|"},{"| \\ "},{"  - "},{"|/\\|"}
    };
char Num[10][5] = {
    {4,3,0,3,4},/*0*/
    {0,1,0,1,0},/*1*/
    {4,1,4,2,4},/*2*/
    {4,1,4,1,4},/*3*/
    {0,3,4,1,0},/*4*/
    {4,2,4,1,4},/*5*/
    {4,2,4,3,4},/*6*/
    {4,1,0,1,0},/*7*/
    {4,3,4,3,4},/*8*/
    {4,3,4,1,4}/*9*/
                    };
char ALetter[26][5] = {
    {4,3,4,3,0},{},{},{},{4,2,4,2,4},/*ABCDE*/
    {},{},{0,3,4,3,0},{},{},/*FGHIJ*/
    {},{},{},{0,5,0,6,0},{},/*KLMNO*/
    {4,3,4,2,0},{},{4,3,4,7,0},{},{},/*PQRST*/
    {},{},{0,3,0,9,0},{},{0,3,4,1,8},/*UVWXY*/
    {}/*z*/
                    };
void PrintALetter(char s[], int n) {
    int a, b, c, tn, t;
    for(a = 0; a < 5; a++) {
        if(a == 0 || a == 2 || a == 4) tn = 1;
        else tn = n;
        for(t = 0; t < tn; t++) {
            for(b = 0; s[b]; b++) {
                if(s[b] == ' ') {putchar(' ');continue;}
                printf("%c", type[ALetter[s[b] - 'A'][a]][0]);
                if(a == 0 || a == 2 || a == 4) {
                    for(c = 0; c < n; c++)
                        printf("%c", type[ALetter[s[b] - 'A'][a]][1]);
                    for(c = 0; c < n; c++)
                        printf("%c", type[ALetter[s[b] - 'A'][a]][2]);
                }
                else if(a == 1){
                    for(c = 0; c < t; c++)    putchar(' ');
                    putchar(type[ALetter[s[b] - 'A'][a]][1]);
                    for(; c < n-1; c++) putchar(' ');
                    for(c = 0; c < n-t-1; c++)    putchar(' ');
                    putchar(type[ALetter[s[b] - 'A'][a]][2]);
                    for(; c < n-1; c++) putchar(' ');
                }
                else {
                    for(c = 0; c < n-t-1; c++)    putchar(' ');
                    putchar(type[ALetter[s[b] - 'A'][a]][1]);
                    for(; c < n-1; c++) putchar(' ');
                    for(c = 0; c < t; c++)    putchar(' ');
                    putchar(type[ALetter[s[b] - 'A'][a]][2]);
                    for(; c < n-1; c++) putchar(' ');
                }
                printf("%c", type[ALetter[s[b] - 'A'][a]][3]);
                if(s[b+1] != '\0') putchar(' ');
            }
            puts("");
        }
    }
}            
void PrintNum(char s[], int n) {
    int a, b, c, tn;
    for(a = 0; a < 5; a++) {
        if(a == 0 || a == 2 || a == 4) tn = 1;
        else tn = n;
        while(tn--) {
            for(b = 0; s[b]; b++) {
                if(s[b] == ' ') {putchar(' ');continue;}
                printf("%c", type[Num[s[b] - '0'][a]][0]);
                for(c = 0; c < n; c++)
                    printf("%c%c", type[Num[s[b] - '0'][a]][1], type[Num[s[b] - '0'][a]][2]);
                printf("%c", type[Num[s[b] - '0'][a]][3]);
                if(s[b+1] != '\0') putchar(' ');
            }
            puts("");
        }
    }
}
main() {
    int n, m, s, tm, ts, a, b;
    char S[20];

    while(scanf("%d %d %d", &n, &m, &s) == 3) {
        if(n == 0 && m == 0 && s == 0) break;
        s = m*60 + s;
        for(a = s; a >= 0; a--) {
            tm = a/60, ts = a%60;
            if(tm < 10) {S[0] = '0', S[1] = tm + '0';}
            else {S[0] = tm/10 + '0', S[1] = tm%10 + '0';}
            for(b = 0; b < n; b++)    S[2+b] = ' ';
            if(ts < 10) {S[3+n-1] = '0', S[4+n-1] = ts + '0';}
            else {S[3+n-1] = ts/10 + '0', S[4+n-1] = ts%10 + '0';}
            S[5+n-1] = '\0', PrintNum(S, n);
        }
        PrintALetter("HAPPY", n);
        PrintALetter("NEWYEAR", n);
    }
    return 0;
}

台長: Morris
人氣(1,054) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: ZeroJudge |
此分類下一篇:d526. Binary Search Tree (BST) (鏈結版本)
此分類上一篇:d718. Waiting In Line

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文