青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數據加載中……

POJ 1048 Follow My Logic 有意思的題

這題很有意思哇。給出一個這樣的東西:
A---+
    |   
    +---:\
        : >o---:\
    +---:/     : )---?
    |      C--o:/
B---+

其中:
        :\               :\                 -:\                 -o:\                       A-o:\
        : )              : >                 : )-                 : )o-                       : )o-?
        :/               :/                 -:/                 --:/                       B--:/
   
     AND gate          OR gate       Gate with inputs    An inverted top input          Two logic input
                                                         and an inverted output         and the output


然后叫你分析它的輸出。
其實哥比較喜歡這種有創意的題,做這種題代碼也寫得比較有意思。


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

struct node {
    
char type, n[3];
    
struct node *child[2];
}
;
struct node nodes[128], *root;
int nodes_cnt;
char map[128][128], input[32];
int W[128], H;

int in_range(int dx, int dy)
{
    
return !(dx < 0 || dx >= W[dy] || dy < 0 || dy >= H);
}


void follow_path(int x, int y, struct node **p_node);

int find_node(int x, int y, struct node **p_node)
{
    
struct node *t;

    
if (map[y][x] >= 'A' && map[y][x] <= 'Z'{
        t 
= &nodes[nodes_cnt++];
        t
->type = map[y][x];
        
*p_node = t;
        
return 1;
    }

    
if (map[y][x] == 'o')
        x
--;
    
if (map[y][x] == ')' || map[y][x] == '>'{
        t 
= &nodes[nodes_cnt++];
        memset(t, 
0sizeof(*t));
        t
->type = map[y][x];
        
*p_node = t;
        
if (in_range(x - 3, y - 1&& map[y - 1][x - 3== 'o')
            t
->n[0= 1;
        
if (in_range(x - 3, y + 1&& map[y + 1][x - 3== 'o')
            t
->n[1= 1;
        
if (in_range(x + 1, y) && map[y][x + 1== 'o')
            t
->n[2= 1;
        follow_path(x 
- 3, y - 1&t->child[0]);
        follow_path(x 
- 3, y + 1&t->child[1]);
        
return 1;
    }


    
return 0;
}


void follow_path(int x, int y, struct node **p_node)
{
    
int i, dx, dy;
    
const struct {
        
char ch;
        
int dx, dy;
    }
 dir[4= {
        
{'-'-10},
        
{'-'10},
        
{'|'01},
        
{'|'0-1}
    }
;

    
while (1{
        
for (i = 0; i < 4; i++{
            dx 
= x + dir[i].dx;
            dy 
= y + dir[i].dy;
            
if (!in_range(dx, dy))
                
continue;
            
if (map[dy][dx] == dir[i].ch || map[dy][dx] == '+')
                
break;
            
if (find_node(dx, dy, p_node))
                
return ;
        }

        
if (i == 4)
            
break;
        map[y][x] 
= '.';
        x 
= dx;
        y 
= dy;
    }


    
*p_node = NULL;
}


int calc(struct node *t)
{
    
if (!t)
        
return 0;
    
if (t->type >= 'A' && t->type <= 'Z')
        
return input[t->type - 'A'- '0';
    
if (t->type == ')'
        
return ((calc(t->child[0]) ^ t->n[0]) & 
                (calc(t
->child[1]) ^ t->n[1])) ^
               t
->n[2];
    
if (t->type == '>')
        
return ((calc(t->child[0]) ^ t->n[0]) | 
                (calc(t
->child[1]) ^ t->n[1])) ^
               t
->n[2];
    
return 0;
}


void find_root()
{
    
int x, y;

    root 
= NULL;
    
for (y = 0; y < H; y++
    
for (x = 0; x < W[y]; x++{
        
if (map[y][x] == '?'{
            follow_path(x, y, 
&root);
            
return ;
        }

    }

}


int main()
{

    freopen(
"e:\\test\\in.txt""r", stdin);

    
while (1{
        nodes_cnt 
= 0;
        H 
= 0;
        
while (1{
            
if (!fgets(map[H], sizeof(map[H]), stdin))
                
return 0;
            
if (map[H][0== '*')
                
break;
            W[H] 
= strlen(map[H]);
            H
++;
        }

        find_root();
        
while (1{
            fgets(input, 
sizeof(input), stdin);
            
if (input[0== '*')
                
break;
            printf(
"%d\n", calc(root));
        }

        printf(
"\n");
    }


    
return 0;
}

posted on 2010-02-13 02:11 糯米 閱讀(600) 評論(0)  編輯 收藏 引用 所屬分類: POJ

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美午夜国产| 欧美三级小说| 极品日韩av| 免费91麻豆精品国产自产在线观看| 亚洲无线一线二线三线区别av| 欧美图区在线视频| 亚洲视频免费看| 亚洲一区日韩在线| 国产视频不卡| 欧美国产三区| 欧美日韩午夜在线| 销魂美女一区二区三区视频在线| 欧美亚洲日本网站| 在线观看国产一区二区| 亚洲人成人99网站| 国产精品白丝黑袜喷水久久久| 欧美在线视频免费| 久久婷婷蜜乳一本欲蜜臀| 亚洲人成人77777线观看| 99亚洲伊人久久精品影院红桃| 国产精品一区一区三区| 免费黄网站欧美| 国产精品wwwwww| 免费不卡视频| 国产精品一区视频| 欧美激情黄色片| 国产精品亚洲美女av网站| 你懂的成人av| 国产精品色在线| 亚洲国产精选| 国产一区二区三区四区老人| 91久久久久久久久久久久久| 欧美日韩1080p| 欧美v日韩v国产v| 国产日韩亚洲| 亚洲最新合集| 亚洲老司机av| 久久久www免费人成黑人精品| 亚洲婷婷综合久久一本伊一区| 久久久久一区二区| 性欧美xxxx视频在线观看| 欧美精品免费视频| 噜噜噜在线观看免费视频日韩| 欧美日韩免费一区二区三区| 欧美插天视频在线播放| 国产欧美日韩亚洲一区二区三区| 亚洲精品综合在线| 亚洲国产欧美一区二区三区久久 | 一色屋精品视频在线观看网站| 亚洲三级影片| 亚洲第一在线视频| 欧美资源在线| 午夜精品一区二区三区电影天堂| 你懂的亚洲视频| 欧美激情在线有限公司| 国产有码在线一区二区视频| 中文无字幕一区二区三区| 99re在线精品| 欧美精品在线极品| 欧美激情2020午夜免费观看| 国产一区视频网站| 性色av一区二区三区红粉影视| 亚洲在线一区二区| 国产精品videosex极品| 一区二区久久久久| 亚洲一区二区黄色| 欧美日韩中文字幕| 亚洲午夜精品久久久久久浪潮| 中文国产一区| 国产精品麻豆欧美日韩ww| 一区二区三区视频免费在线观看| 99精品久久久| 国产精品久久久一本精品| 亚洲一区二区精品| 久久国产精品黑丝| 黄色成人av| 久久综合激情| 亚洲国产精品成人精品| 日韩午夜黄色| 国产精品99免费看 | 亚洲国产mv| 欧美成人精品福利| 亚洲精品老司机| 亚洲免费视频网站| 国产欧美精品一区| 久久精品毛片| 亚洲激情中文1区| 亚洲深夜av| 国产视频久久久久| 榴莲视频成人在线观看| 亚洲欧洲精品一区二区三区波多野1战4| 亚洲乱码久久| 国产精品一卡二| 免费观看一区| 99国产精品私拍| 久久蜜桃香蕉精品一区二区三区| 亚洲福利视频二区| 欧美午夜在线视频| 久久精品国语| 99视频精品免费观看| 久久久久久电影| 日韩一二在线观看| 国产一区二区高清| 欧美经典一区二区三区| 午夜在线播放视频欧美| 欧美激情视频给我| 午夜精品区一区二区三| 揄拍成人国产精品视频| 欧美视频在线免费| 久久亚洲精品视频| 亚洲一区二区三区精品在线观看| 老**午夜毛片一区二区三区| 在线视频精品一区| 亚洲电影免费观看高清| 国产精品久久久久久久久| 久久久99国产精品免费| 宅男噜噜噜66一区二区66| 免费观看成人鲁鲁鲁鲁鲁视频 | 在线精品国产欧美| 国产精品成人一区二区| 欧美91视频| 欧美中文字幕在线| 一区二区三区精品视频| 亚洲第一黄色| 另类酷文…触手系列精品集v1小说| 亚洲天堂av在线免费| 亚洲国产午夜| 国产中文一区二区三区| 国产精品嫩草99a| 欧美日韩美女一区二区| 欧美成人黄色小视频| 亚洲欧美另类久久久精品2019| 夜夜爽av福利精品导航| 亚洲国产精品女人久久久| 久久亚洲精品中文字幕冲田杏梨| 亚洲午夜国产一区99re久久| 亚洲精品一区二区在线观看| 加勒比av一区二区| 狠狠色丁香久久婷婷综合_中| 国产女精品视频网站免费| 国产精品入口| 国产伦精品一区二区三区视频孕妇| 欧美午夜电影网| 国产精品成人在线观看| 国产精品国产馆在线真实露脸| 欧美日韩亚洲一区三区| 欧美日韩视频一区二区三区| 欧美国产日韩一区二区在线观看 | 欧美一级二区| 午夜视频精品| 久久精品天堂| 蜜臀av性久久久久蜜臀aⅴ| 蜜臀99久久精品久久久久久软件 | 亚洲字幕一区二区| 校园春色国产精品| 久久精品99国产精品日本 | 亚洲调教视频在线观看| 亚洲免费在线播放| 欧美一区二区三区免费看 | 免费成人av资源网| 欧美大色视频| 欧美亚日韩国产aⅴ精品中极品| 国产精品久久一级| 国内精品写真在线观看| 亚洲国产精品va在线看黑人动漫| 亚洲精品日韩在线观看| 中文欧美日韩| 久久精品国产亚洲5555| 欧美成人免费观看| avtt综合网| 久久精品视频一| 欧美精品一区在线发布| 国产日韩精品一区二区| 亚洲第一精品在线| 亚洲午夜精品一区二区| 久久天天躁狠狠躁夜夜av| 欧美激情精品久久久久久黑人| 亚洲精品日日夜夜| 欧美一区二区三区视频在线观看| 麻豆国产精品va在线观看不卡 | 久久久久免费观看| 欧美日韩在线播放三区| 国产在线麻豆精品观看| 99精品国产福利在线观看免费| 欧美在线啊v| 亚洲国产三级在线| 午夜久久久久久| 欧美另类视频| 在线观看成人av| 欧美一区亚洲二区| 亚洲精品欧美极品| 久久久国产一区二区| 国产精品播放| 亚洲精品小视频在线观看| 久久久精彩视频| 99精品福利视频| 欧美成人激情在线| 欲香欲色天天天综合和网| 香蕉乱码成人久久天堂爱免费| 亚洲欧洲综合另类|