YTU.2504: 蚂蚁感冒(2)

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

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;
}







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黎曼猜想·

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值