正文

爱因斯坦的思考题2005-12-30 13:46:00

【评论】 【打印】 【字体: 】 本文链接:http://blog.pfan.cn/goal00001111/9079.html

分享到:

/*爱因斯坦的思考题
在网上看到了个有趣的逻辑推理题,爱因斯坦声称世界上只有2%的人能解出:

有五个具有五种不同颜色的房间排成一排;

每个房间里分别住着一个不同国籍的人;

每个人都在喝一种特定品牌的饮料,抽一特定品牌的烟,养一特定的宠物;

没有任意两个人在抽相同品牌的香烟,或喝相同品牌的饮料,或养相同的宠物。

  问题:谁在养鱼作为宠物?

  爱因斯坦给出如下线索:


英国人住在红色的房子里;

瑞典人养狗作为宠物;

丹麦人喝茶;

绿房子紧挨着白房子,在白房子的左边;

绿房子的主人喝咖啡;

抽Pall Mall牌香烟的人养鸟;

黄色房子里的人抽Dunhill牌香烟;

住在中间那个房子里的人喝牛奶;

挪威人住在第一个房子里面;

抽Blends牌香烟的人和养猫的人相邻;

养马的人和抽Dunhill牌香烟的人相邻;

抽BlueMaster牌香烟的人和啤酒;

德国人抽Prince牌香烟;

挪威人和住在蓝房子的人相邻;

抽Blends牌香烟的人和喝矿泉水的人相邻。
编了一个,比较粗糙,比较复杂,敬请改进:

          
           国家           房子           宠物           饮料           香烟
           挪威           黄色             猫         矿泉水        Dunhill
           丹麦           蓝色             马             茶         Blends
           英国           红色             鸟           牛奶       PallMall
           德国           绿色             鱼           咖啡         Prince
           瑞典           白色             狗           啤酒     BlueMaster
 

*/

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

int main(void)
{
 FILE *fp;
 char data[5][40]={"国家","房子","宠物","饮料","香烟"};
 char country[6][40]={" "," "," "," "," "," "};
 char house[6][40]={" "," "," "," "," "," "};
 char pet[6][40]={" "," "," "," "," "," "};
 char drink[6][40]={" "," "," "," "," "," "}; 
 char smoke[6][40]={" "," "," "," "," "," "};
 int i, j, k, l, m, n, o, p, q, r, s, t;
 bool A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12;
 
 if ((fp=fopen("sdfg.txt","w+")) == NULL)
  {
    fprintf(stderr,"\nError opening file \n");
   exit(1);
  } 
 strcpy(country[1],"挪威");//挪威人住在第一个房子里面
 strcpy(house[2],"蓝色");
 strcpy(drink[3],"牛奶");// 住在中间那个房子里的人喝牛奶
  
 for(i=1; i<6; i++)
  for(j=1; j<6; j++)
   for(k=1; k<5; k++)
    for(l=1; l<6; l++)
     for(m=1; m<6; m++)
      for(n=1; n<6; n++)
       for(o=1; o<6; o++)
       {  
        A1 = (i!=1 && i!=2 );//英国人住在红色的房子里;根据房子和国家判断
        A2 = (j!=1 && j!=i ); //瑞典人养狗作为宠物;根据国家和宠物判断
         A3 = (k>3 && k!=i);//绿房子的主人喝咖啡;绿房子紧挨着白房子,在白房子的左边;根据房子和国家判断 
        A4 = (l!=1 && l!=3 && l!=i && l!=j && l!=k); //丹麦人喝茶;根据国家和饮料判断
        A5 = (m!=j);//抽Pall Mall牌香烟的人养鸟;根据香烟和宠物判断
        A6 = (n!=2 && n!=i && n!=k && n!=m); //黄色房子里的人抽Dunhill牌香烟;根据房子和香烟判断 
        A7 = (o!=3 && o!=k && o!=l && o!= m && o!=n );//抽BlueMaster牌香烟的人和啤酒;根据香烟和饮料判断
        if(A1&&A2&&A3&&A4&&A5&&A6&&A7)
        {
         p = 15-1-i-j-l;  //德国人抽Prince牌香烟 ,根据国家判断
         q = 15-m-n-o-p; //抽Blends牌香烟的人和养猫的人相邻,根据香烟判断
         A8 = (p!=1 && p!=i && p!=j && p!=l && p!=m && p!=n && p!=o);//德国人抽Prince牌香烟 ,
         A9 = (q!=m && q!=n && q!=o && q!=p); //抽Blends牌香烟的人和养猫的人相邻,
         if(A8&&A9)
         {
          if(q>1 && (q-1)!=j && (q-1)!=m)//抽Blends牌香烟的人和养猫的人相邻,根据宠物判断
          {
           strcpy(pet[q-1], "猫");
           if(n>1 && (n-1)!=j && (n-1)!=m) 
           {
            strcpy(pet[n-1], "马");
            t = 15-(q-1)-(n-1)-j-m;
            strcpy(pet[t], "鱼");
           }
           else if(n<5 && (n+1)!=j && (n+1)!=m) 
           {
            strcpy(pet[n+1], "马");
            t = 15-(q-1)-(n+1)-j-m;
            strcpy(pet[t], "鱼");
           }
          }
          else if(q<5  && (q+1)!=j && (q+1)!=m)
          {
           strcpy(pet[q+1], "猫");
           if(n>1 && (n-1)!=j && (n-1)!=m) 
           {
            strcpy(pet[n-1], "马");
            t = 15-(q+1)-(n-1)-j-m;
            strcpy(pet[t], "鱼");
           }
          else if(n<5 && (n+1)!=j && (n+1)!=m) 
           {
            strcpy(pet[n+1], "马");
            t = 15-(q+1)-(n+1)-j-m;
            strcpy(pet[t], "鱼");
           }
          }
          //抽Blends牌香烟的人和喝矿泉水的人相邻,根据饮料判断
          if(q>1 && (q-1)!=3 && (q-1)!=k && (q-1)!=l && (q-1)!=o)
            strcpy(drink[q-1],"矿泉水");
          else if(q<5 && (q+1)!=3 && (q+1)!=k && (q+1)!=l && (q+1)!=o)
            strcpy(drink[q+1],"矿泉水");
            //养马的人和抽Dunhill牌香烟的人相邻,根据宠物判断
         //抽Blends牌香烟的人和养猫的人相邻,根据宠物判断
         if((q>1 && (q-1)!=j && (q-1)!=m) ||(q<5  && (q+1)!=j && (q+1)!=m))
         //抽Blends牌香烟的人和喝矿泉水的人相邻,根据饮料判断
          if((q>1 && (q-1)!=3 && (q-1)!=k && (q-1)!=l && (q-1)!=o) ||(q<5 && (q+1)!=3 && (q+1)!=k && (q+1)!=l && (q+1)!=o))  
             //养马的人和抽Dunhill牌香烟的人相邻,根据宠物判断 
             if((n>1 && (n-1)!=j && (n-1)!=m) || (n<5 && (n+1)!=j && (n+1)!=m))
           {  strcpy(country[i],"英国");//英国人住在红色的房子里;
             strcpy(house[i],"红色");
             strcpy(country[j],"瑞典"); //瑞典人养狗作为宠物;
             strcpy(pet[j], "狗");
            strcpy(house[k],"绿色");//绿房子紧挨着白房子,在白房子的左边;                      
              strcpy(house[k+1],"白色") ;
            strcpy(drink[k],"咖啡"); //绿房子的主人喝咖啡;
            strcpy(country[l],"丹麦");//丹麦人喝茶;
            strcpy(drink[l],"茶");
             strcpy(smoke[m],"PallMall");//抽Pall Mall牌香烟的人养鸟;
             strcpy(pet[m],"鸟");
             strcpy(house[n],"黄色"); //黄色房子里的人抽Dunhill牌香烟
             strcpy(smoke[n],"Dunhill"); 
             strcpy(smoke[o],"BlueMaster");//抽BlueMaster牌香烟的人和啤酒
             strcpy(drink[o],"啤酒");
            strcpy(country[p],"德国");//德国人抽Prince牌香烟
             strcpy(smoke[p],"Prince");
             strcpy(smoke[q],"Blends"); //抽Blends牌香烟的人和养猫的人相邻, 
            
            fprintf(fp,"\n");
            fprintf(stdout, "\n");
            for(r=0; r<5; r++) 
            {
             fprintf(stdout, "%15s", data[r]);
             fprintf(fp,"%15s", data[r]);
            }
            fprintf(fp,"\n");
            fprintf(stdout, "\n");
            for(s=1; s<6; s++)
            {
             fprintf(stdout, "%15s", country[s]);
             fprintf(stdout, "%15s", house[s]);
             fprintf(stdout, "%15s", pet[s]);
             fprintf(stdout, "%15s", drink[s]);
             fprintf(stdout, "%15s", smoke[s]);
             fprintf(stdout, "\n");
             fprintf(fp,"%15s", country[s]);
             fprintf(fp,"%15s", house[s]);
             fprintf(fp,"%15s", pet[s]);
             fprintf(fp,"%15s", drink[s]);
             fprintf(fp,"%15s", smoke[s]);
             fprintf(fp,"\n");
             fflush(fp);
            }
           }
          }
        }
       }
 fclose(fp);
  system("pause");
  return 0;
}

阅读(2044) | 评论(0)


版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!

评论

暂无评论
您需要登录后才能评论,请 登录 或者 注册