a*算法最短路径_最长路径算法

a*算法最短路径_最长路径算法#include#include#include#include#include#defineN1000#defineinf1<<30;usingnamespacestd;/* a星算法,找寻最短路径 算法核心:有两个表open表和close表 将方块添加到open列表中,该列表有最小的和值。且将这个方块称为S吧。 将S从open列表移除,然后添加

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

#include <iostream>
#include <cstdio>
#include <queue>
#include <algorithm>
#include <cmath>
#define N 1000
#define inf 1<<30;
using namespace std;
/*
	a星算法,找寻最短路径
	算法核心:有两个表open表和close表
		将方块添加到open列表中,该列表有最小的和值。且将这个方块称为S吧。
		将S从open列表移除,然后添加S到closed列表中。
		对于与S相邻的每一块可通行的方块T:
		如果T在closed列表中:不管它。
		如果T不在open列表中:添加它然后计算出它的和值。
		如果T已经在open列表中:当我们使用当前生成的路径到达那里时,检查F(指的是和值)是否更小。如果是,更新它的和值和它的前继。

		F = G + H        (G指的是从起点到当前点的距离,而H指的是从当前点到目的点的距离(移动量估算值采用曼哈顿距离方法估算)
*/
int map[6][7];     //0表示是路,1表示有阻碍物
int xstart, ystart, xend, yend;       //(x1,y1)起点,(x2, y2)目的点
int close[6][7];  //0表示不在,1表示在
int n;
void astar(int , int );
bool check(int x, int y);
int panyical(int x, int y);
void print2();

struct point{
	int x, y;
	int f, g, h;
	int prex, prey;   //上一个点的x,y	
	point(int x0, int y0, int g0, int h0)
	{
		x = x0;
		y = y0;
		g = g0;
		h = h0;
		f = g + h;
	}
	point(){
	}
}open[N];
void print1(point);        //逆向反推

void init()
{
	xstart = 3, ystart = 1;   //起点
	xend = 4, yend = 5;   //目的点
	map[4][1] = map[1][3] = map[2][3] = map[3][3] = map[4][3] = 1;   //设置阻隔物
	astar(xstart,ystart);
}

point minfpoint()
{
	int flag;
	int minf = inf;
	for(int t=0; t<n; ++t)
	{
		if(close[open[t].x][open[t].y] == 0 && open[t].f <= minf)
		{
			flag = t;
			minf = open[t].f;
		}
	}
	return open[flag];
}
void update(int x, int y, point &s)
{
	for(int t=0; t<n; ++t)
	{
		if(open[t].x == x && open[t].y == y)         //如果该点已经在open表中存在的话,则更新值
		{
			int k = s.g+1+panyical(x, y);
			if(open[t].f > k)
			{
				open[t].f = k;
				open[t].prex = s.x;
				open[t].prey = s.y;
			}
			return ;
		}
	}
	open[n] = point(x, y, s.g+1, panyical(x,y));
	open[n].prex = s.x;
	open[n].prey = s.y;
	n++;
}
void astar(int x, int y)
{
	point s = point(x, y, 0, 0);
	n = 0;
	while(1)
	{
		close[s.x][s.y] = 1;
		if(s.x == xend && s.y == yend)
		{
			break;
		}
		if(check(s.x+1, s.y))
		{
			update(s.x+1, s.y, s);	
		}
		if(check(s.x-1, s.y))
		{
			update(s.x-1, s.y, s);
		}
		if(check(s.x, s.y+1))
		{
			update(s.x, s.y+1, s);
		}
		if(check(s.x, s.y-1))
		{
			update(s.x, s.y-1, s);
		}
		s = minfpoint();
	}
	printf("min:%d g:%d h:%d\n", s.f, s.g, s.h); 
	//print1(s);
	print2();
}

void print1(point p)
{
	point s  = p;
	while(1)
	{
		printf("(%d,%d  g:%d, h:%d f:%d)->", s.x, s.y, s.g, s.h, s.f);
		int prex = s.prex;
		int prey = s.prey;
		if(prex == xstart && prey == ystart)
		{
			break;
		}
		for(int t=0; t<n; ++t)
		{
			if(open[t].x == prex && open[t].y == prey)
			{
				s = open[t];
				break;
			}
		}

	}
}
void print2()
{
	for(int t=0; t<n; ++t)
	{
		point s = open[t];
		printf("(%d,%d  g:%d, h:%d f:%d)\n", s.x, s.y, s.g, s.h, s.f);
		
	}
}
int panyical(int x, int y)
{
	return abs(xend-x) + abs(yend-y);
}

bool check(int x, int y){
	if(x<0 || x>5 || y<0 || y>6 || map[x][y]==1 || close[x][y]==1)
	{
		return false;
	}
	return true;
}
int main()
{
	init();
	return 0;
}

运行结果:

a*算法最短路径_最长路径算法

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/185262.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 链表排序java_java有序链表

    链表排序java_java有序链表这是自己的第一篇博客,话说学习是50%的学习,另外50%是解释,以后会分享自己遇到的一些问题,欢迎各位大佬指教。第一篇对象数组排序的问题处理。..

    2022年10月11日
    3
  • 生成条形码_条形码在线生成器

    生成条形码_条形码在线生成器1usingSystem;2usingSystem.Collections.Generic;3usingSystem.Linq;4usingSystem.Web;5using

    2022年8月5日
    8
  • 计算最长回文子串_用递归判断是否为回文字符串

    计算最长回文子串_用递归判断是否为回文字符串前面我们讲过一个关于字符串的算法:KMP算法。今天我们来讲另外一个字符串算法:Manacher算法。这个算法是用于解决一个问题叫:最长回文子串。前期文章:KMP算法牛客网OJ链接说的简单一点,给定一个字符串,返回的值是这个字符串的最长回文子串的长度。顾名思义,即是回文串,也是子串。文章目录一、BF算法二、Manacher算法一、BF算法那上图的示例2为例:abc1234321ab。最简单的思路就是从左到右遍历每一个字符。每来到一个字符位置,我们可以向左右两边进行扩展,分别比较左右两边的字符。

    2022年10月17日
    3
  • 测试用例模板案例

    测试用例模板案例qq账号:用例编号 所属模块 用例标题 优先级 前置条件 输入数据 操作步骤 预期结果 实际结果 是否通过 测试人员 测试时间 qq_dl_001 登录 账号为六位自然数组成 高 输入账号和密码点击登录 账号:123456密码:abcd12 1:输入账号 2:输入密码 3:点击”登录” 1:账号被填充 2:密码被填充 3:登录成功,跳转主界面 1:账号被填充

    2022年7月17日
    22
  • java线程池executorservice是否结束_java线程池怎么使用

    java线程池executorservice是否结束_java线程池怎么使用本篇主要涉及到的是java.util.concurrent包中的ExecutorService。ExecutorService就是Java中对线程池的实现。一、ExecutorService介绍ExecutorService是Java中对线程池定义的一个接口,它java.util.concurrent包中,在这个接口中定义了和后台任务执行相关的方法:JavaAPI对ExecutorServ

    2025年10月25日
    3
  • Matlab中random函数的使用

    Matlab中random函数的使用原文随机数生成方法:第一种方法是用random语句,其一般形式为              y=random(‘分布的英文名’,A1,A2,A3,m,n),表示生成m行n列的m×n个参数为(A1,A2,A3)的该分布的随机数。例如:(1)R=random(‘Normal’,0,1,2,4):生成期望为0,标准差为1的(2行4…

    2022年6月5日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号