文章目录
- 原题链接
- 题目描述
- 输入格式
- 输出格式
- 数据范围
- 输入样例1:
- 输出样例1:
- 输入样例2:
- 输出样例2:
- 题目分析
- 示例代码
原题链接
1211. 蚂蚁感冒
题目难度:简单
题目来源:第五届蓝桥杯省赛C++ A/B组
题目描述
长 100 厘米的细长直杆子上有 n 只蚂蚁。
它们的头有的朝左,有的朝右。
每只蚂蚁都只能沿着杆子向前爬,速度是 1 厘米/秒。
当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。
这些蚂蚁中,有 1 只蚂蚁感冒了。
并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。
请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。
输入格式
第一行输入一个整数 n, 表示蚂蚁的总数。
接着的一行是 n 个用空格分开的整数 X i X_i Xi, X i X_i Xi 的绝对值表示蚂蚁离开杆子左边端点的距离。
正值表示头朝右,负值表示头朝左,数据中不会出现 0 值,也不会出现两只蚂蚁占用同一位置。
其中,第一个数据代表的蚂蚁感冒了。
输出格式
输出1个整数,表示最后感冒蚂蚁的数目。
数据范围
1
<
n
<
50
1<n<50
1<n<50,
0
<
∣
X
i
∣
<
100
0 < |X_i| < 100
0<∣Xi∣<100
输入样例1:
3
5 -2 8
输出样例1:
1
输入样例2:
5
-10 8 -20 12 25
输出样例2:
3
题目分析
这道题其实就是一个脑筋急转弯,当两只蚂蚁相遇时就会掉头,有一只蚂蚁感冒,在相遇是会传染,从而不断传播,问当所有蚂蚁走出杆子时,有多少只蚂蚁感冒了
首先需要确定的是,所有的蚂蚁是否会离开这个杆子,其次需要确定的是,如何求被感染的蚂蚁的个数
这里其实是有一个等效的思想,假设两只蚂蚁相遇,那么他们会互相掉头,其实就等效他们互相穿过,只是状态不一样,那么对于状态我们也可以分类,两个都没有感冒,则穿过后都不感冒,只要有一个感冒,那么穿过后都感冒
此时问题就简单多了,我们画一个示意图
假设中间的这个蚂蚁感冒了,那么我们就可以知道,在他左边向左走的和在他右边向右走的蚂蚁必定不会感冒,在他右边向左走的蚂蚁必定感冒
在左边向右的蚂蚁就需要分情况讨论了,如果右边有向左走的蚂蚁,那么左边有向右走的蚂蚁都会被感染,如果右边没有,那么左边也都不会被感染,最终就只有最初的蚂蚁
当然这里是只挑选的初始的蚂蚁是向右的情况,如果初始蚂蚁向左就是相反的了
示例代码
#include<iostream>
#include<cmath>
using namespace std;
const int N = 55;
int n;
int arr[N];
int main()
{
cin>>n;
int left = 0, right = 0; // 表示左边向右走的蚂蚁数量,右边向左走的蚂蚁数量
for(int i=0;i<n;i++)
{
cin>>arr[i];
}
for(int i=1;i<n;i++)
{
if(abs(arr[i])<abs(arr[0])&&arr[i]>0) // 在左边且向右走
left++;
else if(abs(arr[i])>abs(arr[0])&&arr[i]<0) // 在右边向左走
right++;
}
if((arr[0]>0&&right==0)||(arr[0]<0&&left==0))
cout<<1<<'\n';
else
cout<<left+right+1<<'\n';
return 0;
}