当前位置: 首页 > news >正文

效果图哪个网站好河南省企业年报网上申报入口

效果图哪个网站好,河南省企业年报网上申报入口,北京网站设计公司youx成都柚米科技15,WordPress验证问题分层图#xff1a; 分层图的最短路#xff1a; 又叫做 扩点最短路。不把实际位置看做是图上的点#xff0c;而是把实际位置及其状态的组合#xff0c;#xff08;一个点有若干的状态#xff0c;所以一个点会扩充出来若干点#xff09;看做是图上的点#xff0c;然后搜索…分层图 分层图的最短路 又叫做 扩点最短路。不把实际位置看做是图上的点而是把实际位置及其状态的组合一个点有若干的状态所以一个点会扩充出来若干点看做是图上的点然后搜索bfs或者dijkstra的过程不变。只是扩了点分层而已。 原理很简单核心在于如何扩点如何到达如何算距离每个题可能都不一样。注意计算扩充之后的点数。 添加链接描述 题意 二维网格只包含空房间障碍起点钥匙和对应的锁只有拿到对应的钥匙才能开对应的锁否则锁的位置和障碍没什么区别无法通过问获得所有钥匙所需要移动的最小次数相当于最短路可以上下左右移动如果无法获得所有的钥匙返回-1 边长最多是30钥匙最多是6 可以用一个数来代表这个点所获得的钥匙的状态。扩充后一共有30302^6 个点。57600个点。我感觉这道题的分层的感觉不是很强烈吧感觉更多的是状态压缩。 使用三元组 x,y,mask表示当前状态。其中(x,y)代表当前所处的位置mask 是一个二进制数长度恰好等于网格中钥匙的数量mask的第I个二进制位为1当且仅当我们已经获得了网格中的第i把钥匙。 之后使用广度优先搜索。 添加链接描述 题意 对于一个有权无向图可以将最多k条边 化为0问从起点到终点的最短路。 分层图可以看成有k1 层图代表了 使用0次1次…k次 的图。 图和图之间 通过权值为0的边连接。 进行扩点最多1e5个点。 使用二维的dis 和vis 数组来标记状态。其中一维代表了使用了几次的免费 dij求 最短路 的时候越晚确定 到原点最短路 的点点 到原点的 距离越远。也就是说 根据 节点 确定dis 的顺序dis 的数值 是不减 的。毕竟后面的点 是前面点 松弛过来的然后边权非负 所以扩点求最短路。最先遇到这个点 某个状态时这个dis 是这个点所有状态里面的最短。 所以 在 dij 如果遇到了终点那么不管他的使用过的免费次数是多少直接返回。 #include bits/stdc.h using namespace std; #define int long long const int N 1e4 10; const int M 5e5 10; int h[M], to[M], ne[M]; int w[M];int tot 1; struct node {int x;int k;// 使用了多少次的 免费机会int y;// 距离bool operator(const node a) const{return a.y y;} }; void add(int u, int v, int ww) {to[tot] v;ne[tot] h[u];w[tot] ww;h[u] tot; }void solve() {int n, m, k;cin n m k;vectorvectorint dis(n, vectorint(k 1, 1e9));vectorvectorint vis(n, vectorint(k 1, 0));int s, e;cin s e;int u, v, ww;while (m--){cin u v ww;add(u, v, ww);add(v, u, ww);}auto dij [](int s) - void{dis[s][0] 0;priority_queuenode q;q.push({s,0,0});// 代表 点使用免费的次数 距离while (!q.empty()){auto ttq.top();int utt.x;int jtt.k; int costtt.y;q.pop();if (vis[u][j])continue;vis[u][j] 1;if (ue){coutcost\n;return; }for (int i h[u]; i; i ne[i]){int v to[i];// 使用 免费 的机会if (j1kdis[v][j1]dis[u][j]){dis[v][j1]dis[u][j];q.push({v,j1,dis[v][j1]});}// 不使用 免费 的机会 if (dis[v][j]dis[u][j]w[i]){dis[v][j]dis[u][j]w[i];q.push({v,j,dis[v][j]});}}}};dij(s);}上面的那种思路其实并没有真正的构建分层图只是用了 增加了 一维的状态。去dp 下面是 构造分层图的代码 需要构建 k1 层。每一层都有n 个节点 #include bits/stdc.h using namespace std; #define int long long #define inf 0x7fffffff const int N 2e5;//9e5 const int M 2e7;// 9e7 int h[N], to[M], ne[M]; int w[M], dis[N]; bool vis[N]; int tot 1; struct node {int x;int y;bool operator(const node a) const{return a.y y;} };void add(int u, int v, int ww) {to[tot] v;ne[tot] h[u];w[tot] ww;h[u] tot; }void dij(int s) {fill(dis, dis N, inf);dis[s] 0;priority_queuenode q;q.push({s, 0});while (!q.empty()){node u q.top();q.pop();if (vis[u.x])continue;vis[u.x] 1;for (int i h[u.x]; i; i ne[i]){int v to[i];if (dis[v] dis[u.x] w[i]){dis[v] dis[u.x] w[i];q.push({v, dis[v]});}}} }void solve() {int n, m, k;cin n m k;int s, e;cin s e;int u, v;int ww;while (m--){// 读进来 一条边将k1 层这条边都给建好cin u v ww;for (int j 0; j k; j){// 建 当前 层add(un*j, vn*j, ww);add(vn*j, un*j, ww);// 连接 这一层 和 下一层的 权值为 0的边使用免费的票if (j ! k){add(u n * j, v n * (j 1), 0);add(v n * j, u n * (j 1), 0);}}}dij(s);int ans inf;for (int j e; j ek * n; j n)ans min(ans, dis[j]);cout ans \n; }signed main() {std::cin.tie(nullptr)-sync_with_stdio(false);int t 1;//cin t;while (t--)solve();return 0; }
http://www.hkea.cn/news/14556808/

相关文章:

  • 淮南做网站推广wordpress 图片地址
  • 网站开发端口查询友情链接查询友情链接检测
  • wordpress 插件手机贵阳做网站seo
  • 检察院门户网站建设自查报告wordpress 继续阅读
  • 网站建设招投标cerntos wordpress
  • 金牛网站建设自己怎么手机做网站
  • 网站开发学习流程图企业网页设计尺寸
  • 模板网站怎么做才美观网站备案核验单
  • 做网站犯法了 程序员有责任吗齐装网
  • html5网站开发实例教程火车wordpress
  • 镜美硅藻泥网站是那家公司做的怎麽用dw做网站轮播海报
  • 花垣县建设局网站html5单页网站
  • 网站公告栏代码山西建立网站营销策划
  • 成都什么是网站建设天津网站建设 熊掌号
  • 做网站体会心得网站怎么不要钱自己做
  • 青岛市城市建设局网站静态网站模板下载
  • 织梦网站被黑做网站要多长时间
  • 松江网站建设推广wordpress 相册形式
  • 网站会员方案怎么找需要推广的商家
  • 钢铁网站模板电子信息工程能进国家电网吗
  • 做屏保那个网站下载图好公司企业宣传片制作公司
  • 佛山做网站优化做网站做哪个好
  • 可以做用户旅程图的网站企业型网站建设咨询电话
  • 网站建设sql语句留言板木疙瘩h5制作
  • 网站公司怎么做的wordpress 几百万数据
  • 成都平台网站建设公司网站开发详细介绍
  • 校园网站建设目标直播秀场网站开发
  • 巴彦淖尔 网站建设珠宝类网站建设
  • 公司网站建设网络推广wordpress 嵌入python
  • 直播网站的建设龙岗网络推广方式