算法提高 扶老奶奶过街
2017-01-08 11:56
369 查看
一共有5个红领巾,编号分别为A、B、C、D、E,老奶奶被他们其中一个扶过了马路。
五个红领巾各自说话:
A :我和E都没有扶老奶奶
B :老奶奶是被C和E其中一个扶过大街的
C :老奶奶是被我和D其中一个扶过大街的
D :B和C都没有扶老奶奶过街
E :我没有扶老奶奶
已知五个红领巾中有且只有2个人说的是真话,请问是谁扶这老奶奶过了街?
若有多个答案,在一行中输出,编号之间用空格隔开。
例如
A B C D E(这显然不是正确答案)
#include "stdio.h"
int main()
{
int a[5]={0} ;
int i,sum ;
for(i=0;i<5;i++)
{
a[i]=1 ;
sum=0 ;
if(a[0]==0&&a[4]==0)
sum++;
if(a[2]==1||a[4]==1)
sum++;
if(a[2]==1||a[3]==1)
sum++;
if(a[1]==0&&a[2]==0)
sum++;
if(a[4]==0)
sum++;
if(sum==2)
{
switch(i)
{
case 0 :
printf("A ");
break ;
case 1 :
printf("B ");
break ;
case 2 :
printf("C ");
break ;
case 3 :
printf("D ");
break ;
case 4 :
printf("E ");
break ;
}
}
a[i]=0 ;
}
return 0 ;
}
五个红领巾各自说话:
A :我和E都没有扶老奶奶
B :老奶奶是被C和E其中一个扶过大街的
C :老奶奶是被我和D其中一个扶过大街的
D :B和C都没有扶老奶奶过街
E :我没有扶老奶奶
已知五个红领巾中有且只有2个人说的是真话,请问是谁扶这老奶奶过了街?
若有多个答案,在一行中输出,编号之间用空格隔开。
例如
A B C D E(这显然不是正确答案)
#include "stdio.h"
int main()
{
int a[5]={0} ;
int i,sum ;
for(i=0;i<5;i++)
{
a[i]=1 ;
sum=0 ;
if(a[0]==0&&a[4]==0)
sum++;
if(a[2]==1||a[4]==1)
sum++;
if(a[2]==1||a[3]==1)
sum++;
if(a[1]==0&&a[2]==0)
sum++;
if(a[4]==0)
sum++;
if(sum==2)
{
switch(i)
{
case 0 :
printf("A ");
break ;
case 1 :
printf("B ");
break ;
case 2 :
printf("C ");
break ;
case 3 :
printf("D ");
break ;
case 4 :
printf("E ");
break ;
}
}
a[i]=0 ;
}
return 0 ;
}
相关文章推荐
- 蓝桥杯 算法提高 扶老奶奶过街
- 蓝桥杯 ADV-143算法提高 扶老奶奶过街
- 蓝桥杯算法提高——扶老奶奶过街(逻辑推理)
- 算法笔记_152:算法提高 扶老奶奶过街(Java)
- 蓝桥杯 算法提高 扶老奶奶过街
- 蓝桥杯 算法提高 扶老奶奶过街
- 算法提高 扶老奶奶过街 (逻辑推理)
- 算法提高 扶老奶奶过街
- 算法提高 ADV-143 扶老奶奶过街
- 算法提高 扶老奶奶过街
- 蓝桥杯ADV-143——算法提高 扶老奶奶过街
- 算法提高 扶老奶奶过街 蓝桥杯 java详解
- 算法提高 扶老奶奶过街
- 蓝桥杯-算法提高(ADV-143 扶老奶奶过街)
- 算法提高 扶老奶奶过街
- 算法提高 扶老奶奶过街
- 蓝桥杯 算法提高 算法提高 扶老奶奶过街
- 算法提高 扶老奶奶过街
- 蓝桥杯 算法提高 扶老奶奶过街
- 蓝桥杯-算法提高 学霸的迷宫(BFS-倒向追踪输出移动方向)