蚂蚁感冒问题暴力解决

问题重述:

长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。 
  每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。 
  当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。 
  这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。 
  请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。 

输入格式: 

   第一行输入一个整数n  (1  <   n  <   50),  表示蚂蚁的总数。 
  接着的一行是n个用空格分开的整数  Xi  (-100  <   Xi  <   100),  Xi的绝对值,表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左,数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中,第一个数  据代表的蚂蚁感冒了。 

输出格式: 

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

样例输入: 


5  -2  8 

样例输出: 


样例输入: 


-10  8  -20  12  25 

样例输出: 


在老赵的提醒下,首先相向而行的蚂蚁碰面后掉头可以看成是直接擦肩而过继续保持方向向前;对于蚂蚁有如下几种情况:
1.和感冒蚂蚁方向相反的两种情况:
(1)与感冒蚂蚁背道而驰,这类蚂蚁绝对不会被传染;
(2)与感冒蚂蚁相向而行,这类蚂蚁必然被传染;
2.和感冒蚂蚁同方向的两种情况:
(1)在感冒蚂蚁的前面,这类蚂蚁也不会被传染,因为所有蚂蚁等速,感冒蚂蚁追不上在其前方的蚂蚁;
(2)在感冒蚂蚁后面,首先这类蚂蚁又有两种可能,
a)如果存在1中的(2)那一类蚂蚁,则感冒蚂蚁先传染相向而来的蚂蚁,被传染的蚂蚁又传染第一只感冒蚂蚁后面的蚂蚁;
       b)如果不存在上述情况,感冒蚂蚁后面的蚂蚁也不会被传染;

据此得到程序如下:
import java.util.Arrays;
import java.util.Scanner;
public class Main{

	public static void main(String []arg){
		Scanner cin=new Scanner(System.in);
		while(cin.hasNext()){
			int n=cin.nextInt();
			int a[]=new int[n];
			for(int i=0;i<n;i++)
				a[i]=cin.nextInt();
			boolean flag=false;
			int sum=1;
			for(int i=1;i<a.length;i++){
				if((Math.abs(a[i])-Math.abs(a[0]))*a[0]>0 && a[0]*a[i]<0){
					sum++;
					flag=true;
				}
			}
			if(flag){
				for(int i=1;i<a.length;i++){
					if((Math.abs(a[0])-Math.abs(a[i]))*a[i]>0 && a[0]*a[i]>0)  
						sum++;
				}
			}
			System.out.println(sum);
		}
		cin.close();
	}
}

### 关于蓝桥杯竞赛中的蚂蚁感冒问题 #### 问题描述 在一个很长的数轴上,有 N 只蚂蚁分别朝不同的方向移动。当两只蚂蚁相遇时,它们会改变方向继续前进。如果一只蚂蚁被另一只携带“感冒”的蚂蚁碰到,则这只蚂蚁也会得感冒。给定每只蚂蚁的位置和初始方向以及其中有一只蚂蚁已经患上了感冒,求最终会有多少只蚂蚁患上感冒。 #### Python解决方案实现 对于这个问题的一种有效解法是模拟整个过程并追踪哪些蚂蚁会被感染。由于碰撞不会影响最终的结果——即两只会相撞的蚂蚁只是交换了身份——因此可以简化处理逻辑来计算最终有多少蚂蚁患病[^1]。 ```python def count_cold_ants(N, positions, directions): cold_count = 0 # 假设第一个生病的蚂蚁位于positions列表的第一个位置 infected_side = 'left' if directions[0] == '<' else 'right' for i in range(N): if (infected_side == 'left' and directions[i] == '>') or \ (infected_side == 'right' and directions[i] == '<'): break if directions[i] != infected_side: continue cold_count += 1 return cold_count N = int(input().strip()) positions_directions = input().strip() # 将输入字符串解析成两个独立数组:position 和 direction directions = [] for char in positions_directions: if char in ('<', '>'): directions.append(char) print(count_cold_ants(N, None, directions)) ``` 此代码片段定义了一个函数`count_cold_ants`, 它接收三个参数:N表示蚂蚁的数量; `positions` 表示每只蚂蚁所在的位置(在这个例子中并未实际使用); `directions` 是一个字符列表,代表各只蚂蚁的方向(左向 `<` 或右向 `>`)。该算法假设第一只蚂蚁已经被传染,并基于这个前提条件遍历所有蚂蚁以统计可能被传染的数量。 需要注意的是,在真实比赛中应当仔细阅读具体题目要求,因为这里给出的例子做了某些简化假定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值