蓝桥杯-蚂蚁感冒

长 100 厘米的细长直杆子上有 n 只蚂蚁。

它们的头有的朝左,有的朝右。

每只蚂蚁都只能沿着杆子向前爬,速度是 1 厘米/秒。

当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。

这些蚂蚁中,有 1 只蚂蚁感冒了。

并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。

请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。

输入格式

第一行输入一个整数 n, 表示蚂蚁的总数。

接着的一行是 n 个用空格分开的整数 Xi, Xi 的绝对值表示蚂蚁离开杆子左边端点的距离。

正值表示头朝右,负值表示头朝左,数据中不会出现 0 值,也不会出现两只蚂蚁占用同一位置。

其中,第一个数据代表的蚂蚁感冒了。

输出格式

输出1个整数,表示最后感冒蚂蚁的数目。

数据范围

1<n<50,
0<|Xi|<100

输入样例1:

3
5 -2 8

输出样例1:

1

输入样例2:

5
-10 8 -20 12 25

输出样例2:

3

题解:

这题正常模拟的话, 比较麻烦, 而且容易出错, 这里我们换个思路~

  • 感冒的蚂蚁和正常的蚂蚁相撞后转向, 相当于这两只蚂蚁穿过对方, 继续按照原来的方向爬行, 正常的蚂蚁变的感冒
  • 设第一支感冒的蚂蚁是 x, 不论 x 是向左还是向右, x 左边的向左爬的蚂蚁 和 x 右边的向右爬的蚂蚁 都不会被感染

下面这句话, 结合着下图看比较好理解 --> (图中的 l 和 r 代表的是 x左边的向右爬的蚂蚁的数量 和 x右边的向左爬的蚂蚁的数量)
假设 x 向右, 那么 x 右边的 向左爬的蚂蚁一定被感染, 如果存在 "右边的 向左爬的蚂蚁", 那么 x 左边的向右爬的蚂蚁同样会被感染, 否则 "x 左边的向右爬的蚂蚁同样会被感染" 不会被感染

x 向左的话, 跟向右的情况相反, x左边向右的一定感染, 如果存在 "x左边向右的", 那么 x 右边向左的才会被感染, 否则不会


ac代码👇

#include <bits/stdc++.h>
using namespace std;
vector<int> v;
int main()
{
    int n; cin >> n;
    v.resize(n);
    for (int i = 0; i < n; i ++) cin >> v[i];
    
    int t = abs(v[0]);
    int l = 0, r = 0;   // 左边 向右走的, 和 右边 向左走的
    for (int i = 0; i < n; i ++)
        if (abs(v[i]) < t && v[i] > 0) l ++;
        else if (abs(v[i]) > t && v[i] < 0) r ++;
    
    if ((v[0] < 0 && l == 0) || (v[0] > 0 && r == 0)) cout << 1 << endl;
    else cout << l + r + 1 << endl;
    return 0;
}

觉得写的不错的话, 点个赞吧~

热门相关:强宠头号鲜妻:陆少,滚!   重生不嫁豪门   太监武帝   人族镇守使   闪婚总裁很惧内