[蓝桥杯 2014 省 AB] 蚂蚁感冒

前言:

今天在写题的时候遇到了这道题,觉得这道题虽然只是一道模拟实现的题型,但是我觉得他的解题思路十分的震惊我,所以我来分享一下这道题的题解,以及思路.

题目解读:

题目的意思就是在一根麻绳上有n只蚂蚁,分别给出这几只蚂蚁的坐标和运动的方向,第一只蚂蚁是患有病毒的蚂蚁,只要和他碰面就会感染上病毒.让我们求最后的患病的蚂蚁的个数.

解题思路:

一开始我看到这道题的时候在想着怎么模拟实现蚂蚁相遇的场景,但是我的能力有限,根本无法模拟蚂蚁掉头的场景,然后我们来看这几只蚂蚁的运动的速度是一样的,所以只要是同向运动的蚂蚁在不掉头的前提下他们就一定不会相遇,但是这道题难得地方就是这蚂蚁会掉头.....

但是我们这样想假设A-> <-B这样的情景当他们相遇后的场景就变成了这样.

<-A B-> 我们是不是可以看作这样的图

<-B A->我们就让相遇过后改变的只是蚂蚁的患病的状态,就像幽灵一样穿过去,因为掉头总是会有一个蚂蚁接替他对方蚂蚁的运动的状态.

所以我们的解题思路出现了:

当患病的蚂蚁是向左移动的时候,如果这只蚂蚁的左边有向右移动的蚂蚁,那么患病的蚂蚁就是在左边的向右移动的蚂蚁+右边向左移动的蚂蚁+1;

如果没有的话就是1

那么如果患病的蚂蚁是向右移动的话,我们看如果右边有向左移动的蚂蚁的话,答案就是:

右边向左移动的蚂蚁+左边向右移动的蚂蚁+1

如果右边没有向左移动的蚂蚁那么答案就是1

到这里我们的解题的核心思路就捋顺了

下面就是代码的实现了;

代码实现:

cpp 复制代码
#include<iostream>
#include<cmath>
using namespace std;
const int N=60;
int a[N];
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
	  cin>>a[i];	
	}
	int x=a[1];
	if(x<0)
	{
		int ret=0;
	for(int i=2;i<=n;i++)
	{
		if(fabs(a[i])<fabs(x)&&a[i]>0)
		{
			ret++;
		}
	}
	if(ret==0)
	{
		cout<<ret+1;
	}else
	{
		for(int i=2;i<=n;i++)
		{
			if(fabs(a[i])>fabs(x)&&a[i]<0)
			{
				ret++;
			}
		}
			cout<<ret+1;
	}

	}else
	{
			int ret=0;
	for(int i=2;i<=n;i++)
	{
		if(fabs(a[i])>fabs(x)&&a[i]<0)
		{
			ret++;
		}
	}
	if(ret==0)
	{
		cout<<ret+1;
	}else
	{
		for(int i=2;i<=n;i++)
		{
			if(fabs(a[i])<fabs(x)&&a[i]>0)
			{
				ret++;
			}
		}
		cout<<ret+1;
	}
	
	}
	
	return 0;
}
相关推荐
IT猿手2 小时前
基于强化学习Q-learning算法的无人机三维路径规划算法原理与实现,MATLAB代码
算法·matlab·无人机·路径规划·动态路径规划
qq_417695052 小时前
C++中的解释器模式
开发语言·c++·算法
y = xⁿ2 小时前
【LeetCodehot100】T108:将有序数组转换为二叉搜索树 T98:验证搜索二叉树
数据结构·算法·leetcode
程序员小崔日记3 小时前
一道KMP统考真题彻底讲透:nextval与滑动距离的本质
算法·408·王道计算机考研
xiaoye-duck3 小时前
《算法题讲解指南:动态规划算法--路径问题》--9.最小路径和,10.地下城游戏
c++·算法·动态规划
渡过晚枫3 小时前
[第十四届蓝桥杯/java/算法]国赛A——跑步计划
算法
hanlin033 小时前
刷题笔记:力扣第17题-电话号码的字母组合
笔记·算法·leetcode
不是株3 小时前
算 法
数据结构·python·算法
云泽8083 小时前
蓝桥杯算法精讲:从宏观角度重新认识递归
算法·职场和发展·蓝桥杯