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

做经营网站怎么赚钱爱站网是什么

做经营网站怎么赚钱,爱站网是什么,下载做网站的软件,昆明网站建设公司_本题链接:登录—专业IT笔试面试备考平台_牛客网 题目: 样例: 输入 2 10 (JOKERjoke #####asdr) 输出 12 思路: 根据题意,要求最短时间,实际上也可以理解为最短距离。 所以应该联想到有关最短距离的算法&…

本题链接:登录—专业IT笔试面试备考平台_牛客网

题目:

样例:

输入
2 10
(JOKERjoke
#####asdr)
输出
12

思路:

        根据题意,要求最短时间,实际上也可以理解为最短距离。

        所以应该联想到有关最短距离的算法,在这里给出的 n,m是100,所以我们可以暴力求最短距离即可,身份碎片虽然分大小写,但是它们都是唯一的点,所以可以通过Floyd,记录每个点之间的最短距离,随后累加即可,其次这里的最短距离可以用BFS求得最短距离。注意一个细节,初始化无穷大的时候,尽量小一些,否则多个INF累加爆 long long 就会答案错误。

代码详解如下:

#include <iostream>
#include <vector>
#include <queue>
#include <climits>
#include <algorithm>
#define endl '\n'
#define int long long
#define x first
#define y second
#define umap unordered_map
#define All(x) x.begin(),x.end()
#pragma GCC optimize(3,"Ofast","inline")
#define IOS std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 2e6 + 10;
inline void solve();signed main()
{
//	freopen("a.txt", "r", stdin);IOS;int _t = 1;// cin >> _t;while (_t--){solve();}return 0;
}
using PII = pair<int,int>;
int n,m;
PII rem[256];	// rem 记录最短路中字符的位置
char g[110][110];int dist[256][256];	// Floyd最短距离int dx[] = {0,1,0,-1};
int dy[] = {1,0,-1,0};
// BFS 求字符a 到字符 b 之间的最短路
inline int Dist(char a,char b)
{// 标记是否走动过当前位置vector<vector<bool>>st(110,vector<bool>(110,false));// 判断是否可以走动的条件auto isRun = [&](int x,int y)->bool{return (x >= 0 and x < n and y >= 0 and y < m and !st[x][y] and g[x][y] != '#');};// BFS 求最短路int step = 0;queue<PII>q;q.emplace(rem[a]);while(q.size()){int sz = q.size();while(sz--){PII now = q.front();q.pop();if(g[now.x][now.y] == b){rem[b] = now;	// 记录当前最短路的位置return step;}st[now.x][now.y] = true;for(int i = 0;i < 4;++i){int bx = now.x + dx[i];int by = now.y + dy[i];if(isRun(bx,by)){st[bx][by] = true;q.emplace(PII(bx,by));}}}++step;}// 返回无穷大return INT_MAX;
}inline void solve()
{// 拿取碎片的方案vector<char>plan = {'J','O','K','E','R','j','o','k','e','r'};cin >> n >> m;for(int i = 0;i < n;++i){for(int j = 0;j < m;++j){char c;cin >> c;g[i][j] = c;// 存储好起点和终点的位置if(c == '(') rem[c] = PII(i,j);if(c == ')') rem[c] = PII(i,j);}}// 存储起点到各个字符之间的最短距离for(char &p:plan) dist['('][p] = Dist('(',p);// 存储终点到各个字符之间的最短距离for(char &p:plan) dist[p][')'] = Dist(')',p);// 存储各个点之间的最短距离for(char &st:plan){for(char &ed:plan){if(st == ed) continue;dist[st][ed] = Dist(st,ed);}}sort(All(plan));// 全排列遍历所有的捡碎片方案// 获取最小的一种答案即可int ans = INT_MAX;do{int res = 0;res += dist['('][*plan.begin()]; //累加起点开始的最短距离for(int i = 1;i < 10;++i) res += dist[plan[i - 1]][plan[i]];	// 按顺序累加最短距离res += dist[plan.back()][')'];	// 累加最后到终点最短距离ans = min(ans,res);}while(next_permutation(All(plan)));if(ans >= INT_MAX) cout << "-1" << endl;else cout << ans << endl;
}

最后提交:

http://www.hkea.cn/news/15447/

相关文章:

  • 网站计数器php百度广告推广收费标准
  • 安徽省建设网站每天看七个广告赚40元的app
  • 个人单页网站建设百度主页入口
  • 网站设计简单网页杭州余杭区抖音seo质量高
  • 建设工程信息在哪个网站百度竞价排名广告定价鲜花
  • Javaweb网站建设成品网站源码
  • xp做的网站有连接限制广告软文案例
  • seo专员是干嘛的重庆seo网站排名
  • 企业收录网站有什么用个人免费网上注册公司
  • 网站营销目标东莞优化怎么做seo
  • 网站城市分站是怎么做的网站建设制作公司
  • 清远网站设计公司百度推广登录入口电脑
  • 贵阳做网站公司吗常用的seo工具推荐
  • 运营网站团队建设如何用百度平台营销
  • 南阳网网站建设如何做好搜索引擎优化工作
  • 服务好的徐州网站建设网址seo优化排名
  • 站长工具域名备案查询网络平台推广具体是怎么推广
  • 做网站买什么香港服务器吗如何查看网站收录情况
  • 重庆做网站及公众号公司淘宝网店怎么运营起来
  • 旅游网站规划设计腾讯企点官网下载
  • 小说网站系统怎么做百度用户服务中心电话
  • c做网站教程郑州关键词网站优化排名
  • dreawever如何做本地网站营销技巧五步推销法
  • 高安市帮助做公司网站武汉seo外包平台
  • 做阿里网站需要的faq惠州网站seo排名优化
  • 不花钱可以做网站吗长春seo网站管理
  • 专业制作网站电脑关键词排名靠前
  • 自适应网站制作教程预测2025年网络营销的发展
  • 建设网站需要什么资质竞价排名什么意思
  • 高端网站建设公司增长广西壮族自治区