洛谷P1367 蚂蚁

题目描述 https://www.luogu.org/problemnew/show/P1367
看似模拟,却不是模拟。
两个蚂蚁相碰,实际上就是互换名字的蚂蚁互相穿过去,而且相对位置没有变化,比如 2与3相碰(2在前),碰完后,2还在3前面。、
所以只要序号的位置就行了,第一次排序后,记录第i个点以前的位置,因为相对位置不会改变,所以就需要记录一次就行了。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> 
using namespace std;
const int N=1e5+5;
struct node
{
	int x,d,num;
}ant[N];
int n,t,p[N];
bool cmp(const node &a,const node &b)
{
	return a.x<b.x;
}
int main() 
{ 
   scanf("%d%d",&n,&t);
   for(int i=1;i<=n;i++)
   {
   	  scanf("%d%d",&ant[i].x,&ant[i].d);
   	  ant[i].num=i;
   }
   sort(ant+1,ant+n+1,cmp);
   for(int i=1;i<=n;i++)
   {
   	  p[ant[i].num]=i;
   	  ant[i].x+=ant[i].d*t;
   }
   sort(ant+1,ant+n+1,cmp);
   for(int i=1;i<n;i++)
     if(ant[i].x==ant[i+1].x) ant[i].d=ant[i+1].d=0;
   for(int i=1;i<=n;i++)
     printf("%d %d\n",ant[p[i]].x,ant[p[i]].d); 
 	
  return 0;	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
蚂蚁算法是一种基于觅食行为的仿生优化算法,灵感来源于蚂蚁在寻找食物、寻路和寻找最优路径的行为。蚂蚁算法模拟了蚂蚁在觅食过程中的信息交流与协作,其主要应用在组合优化问题中。 蚂蚁算法的基本原理是通过模拟蚂蚁在寻找食物的过程中释放信息素与蒸发信息素的行为来实现全局搜索与局部优化的策略。在算法中,每个蚂蚁都具有感知环境并具备随机选择路径的能力,蚂蚁会在路径上释放信息素,并根据路径上信息素浓度选择下一个位置。而信息素的浓度则受到路径长度和路径上信息素的衰减影响。 蚂蚁算法通过迭代寻找解空间中的最优解,每次迭代都会更新信息素浓度,并根据蚂蚁的觅食经验来调整路径选择的概率。这样,在演化的过程中,较优解上信息素的浓度逐渐增加,进而吸引更多蚂蚁选择该路径,从而实现对解空间的搜索和优化。 蚂蚁算法的优点在于其能在较短的时间内找到接近最优解的解,并且对于大规模组合优化问题有较好的鲁棒性。此外,蚂蚁算法还可以应用在图论、网络路由、机器学习等领域中。 总而言之,蚂蚁算法是一种基于觅食行为的仿生优化算法,通过模拟蚂蚁在寻找食物的过程中的信息交流与协作,来寻找组合优化问题的最优解。它具有全局搜索能力和局部优化能力,适用于大规模问题,且易于实现和灵活应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值