2504: 蚂蚁感冒
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 391 Solved: 162
[ Submit][ Status][ Web Board]
Description
长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。 当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。
请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。
Input
第一行输入一个整数n (1 < n < 50), 表示蚂蚁的总数。 接着的一行是n个用空格分开的整数 Xi (-100 < Xi < 100), Xi的绝对值,表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左,数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中,第一个数据代表的蚂蚁感冒了。
Output
要求输出1个整数,表示最后感冒蚂蚁的数目。
Sample Input
3
5 -2 8
Sample Output
1
HINT
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
思路分析:
第一只蚂蚁一定是感冒的,它会感染与它碰面的其他蚂蚁,题目中说两只蚂蚁碰面后会掉头。其实吧,它掉不掉头其实效果都是一样的,人家还懒得掉头呢,我们不需要知道谁感染了谁,只要知道都有哪些被感染了即可。那么,如果第一只蚂蚁头朝右,那它势必会感染到它的右侧所有头向左的蚂蚁,这些头向左的蚂蚁又会去感染他左侧所有头向右的蚂蚁。
所以,只需要统计出第一只蚂蚁左侧头朝右的蚂蚁和第一只蚂蚁右侧头朝左的蚂蚁的数量,然后加上它本身就是所有被感染的蚂蚁数量。但是有个特殊点需要注意一下,第一只蚂蚁头朝右时要保证他的右侧一定有头向左的蚂蚁才行。
AC代码:
#include <stdio.h>
#include <stdlib.h>
struct ANT
{
int loc;//在第一个蚂蚁的左侧还是右侧
//1表示右侧,-1表示左侧
int dir;//头的方向
};
struct ANT ant[60];
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
int i;
int cold=1,rr,rl,lr,ll;
rr=rl=lr=ll=0;
int a[n];
for(i=0; i<n; i++)
scanf("%d",&a[i]);
//处理数据
for(i=1; i<n; i++)
{
ant[i].dir=1;//初始化默认所有蚂蚁头朝右
ant[i].loc=1;//初始化默认所得蚂蚁都在第一只蚂蚁的右侧
if(fabs(a[i])<fabs(a[0]))
{
ant[i].loc=-1;//到左边端点距离小于第一只蚂蚁,则在它的左侧,更新数据。
}
if(a[i]<0)
ant[i].dir=-1;//输入数据<0表示头朝左
}
for(i=1; i<n; i++)
{
if(ant[i].loc==1&&ant[i].dir==-1)//右侧头朝左的
rl++;
if(ant[i].loc==1&&ant[i].dir==1)//右侧头朝右的
rr++;
if(ant[i].loc==-1&&ant[i].dir==1)//左侧头朝右的
lr++;
if(ant[i].loc==-1&&ant[i].dir==-1)//左侧头朝左的
ll++;
}
if(a[0]>0&&rl!=0)//感冒的蚂蚁头朝右
cold=rl+lr+1;
if(a[0]<0&&lr!=0)//感冒的蚂蚁头朝左
cold=rr+ll+1;
printf("%d\n",cold);
}
return 0;
}