[蓝桥杯 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;
}
相关推荐
小欣加油2 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly2 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕4 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei4 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld5 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi86 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang7 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby7 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠8 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力9 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试