YTU.2504: 蚂蚁感冒(2)
原创
©著作权归作者所有:来自51CTO博客作者mb614decb9ad0b0的原创作品,请联系作者获取转载授权,否则将追究法律责任
2504: 蚂蚁感冒
Time Limit: 1 Sec
Memory Limit: 128 MB
Submit: 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
Sample Output
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;
}