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

百度建设网站/怎么推广自己的产品

百度建设网站,怎么推广自己的产品,营销软件站,政府门户网站互动建设的背景LeetCode 399 给你一个变量对数组 equations 和一个实数值数组 values 作为已知条件,其中 equations[i] [Ai, Bi] 和 values[i] 共同表示等式 Ai / Bi values[i] 。每个 Ai 或 Bi 是一个表示单个变量的字符串。 另有一些以数组 queries 表示的问题,其…

LeetCode 399

给你一个变量对数组 equations 和一个实数值数组 values 作为已知条件,其中 equations[i] = [Ai, Bi]values[i] 共同表示等式 Ai / Bi = values[i] 。每个 AiBi 是一个表示单个变量的字符串。

另有一些以数组 queries 表示的问题,其中 queries[j] = [Cj, Dj] 表示第 j 个问题,请你根据已知条件找出 Cj / Dj = ? 的结果作为答案。

返回 所有问题的答案 。如果存在某个无法确定的答案,则用 -1.0 替代这个答案。如果问题中出现了给定的已知条件中没有出现的字符串,也需要用 -1.0 替代这个答案。

注意:输入总是有效的。你可以假设除法运算中不会出现除数为 0 的情况,且不存在任何矛盾的结果。

示例 1:

输入:equations = [["a","b"],["b","c"]], values = [2.0,3.0], queries = [["a","c"],["b","a"],["a","e"],["a","a"],["x","x"]]
输出:[6.00000,0.50000,-1.00000,1.00000,-1.00000]
解释:
条件:a / b = 2.0, b / c = 3.0
问题:a / c = ?, b / a = ?, a / e = ?, a / a = ?, x / x = ?
结果:[6.0, 0.5, -1.0, 1.0, -1.0 ]

示例 2:

输入:equations = [["a","b"],["b","c"],["bc","cd"]], values = [1.5,2.5,5.0], queries = [["a","c"],["c","b"],["bc","cd"],["cd","bc"]]
输出:[3.75000,0.40000,5.00000,0.20000]

示例 3:

输入:equations = [["a","b"]], values = [0.5], queries = [["a","b"],["b","a"],["a","c"],["x","y"]]
输出:[0.50000,2.00000,-1.00000,-1.00000]

提示:

  • 1 <= equations.length <= 20
  • equations[i].length == 2
  • 1 <= Ai.length, Bi.length <= 5
  • values.length == equations.length
  • 0.0 < values[i] <= 20.0
  • 1 <= queries.length <= 20
  • queries[i].length == 2
  • 1 <= Cj.length, Dj.length <= 5
  • Ai, Bi, Cj, Dj 由小写英文字母与数字组成

思路:

Floyd.

可以把这个看成是一个图,求两点之间最短距离。

代码:

class Solution {
public:vector<double> calcEquation(vector<vector<string>>& equations, vector<double>& values, vector<vector<string>>& queries) {vector<double> v;int n=0;unordered_map<string,int> m;for(int i=0;i<equations.size();i++){if(m.find(equations[i][0])==m.end())m[equations[i][0]]=n++;if(m.find(equations[i][1])==m.end())m[equations[i][1]]=n++;}vector<vector<double> >g(n, vector<double>(n, -1.0));for(int i=0;i<equations.size();i++){int a=m[equations[i][0]],b=m[equations[i][1]];g[a][b]=values[i];g[b][a]=1.0/values[i];}for (int k = 0; k < n; k++) {for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {if(g[i][k]>0&&g[k][j]>0)g[i][j]=g[i][k]*g[k][j];}}}for(int i=0;i<queries.size();i++){if(m.find(queries[i][0])==m.end()||m.find(queries[i][1])==m.end()){v.push_back(-1.0);continue;}int a=m[queries[i][0]],b=m[queries[i][1]];v.push_back(g[a][b]);}return v;}
};

LeetCode406

假设有打乱顺序的一群人站成一个队列,数组 people 表示队列中一些人的属性(不一定按顺序)。每个 people[i] = [hi, ki] 表示第 i 个人的身高为 hi ,前面 正好ki 个身高大于或等于 hi 的人。

请你重新构造并返回输入数组 people 所表示的队列。返回的队列应该格式化为数组 queue ,其中 queue[j] = [hj, kj] 是队列中第 j 个人的属性(queue[0] 是排在队列前面的人)。

示例 1:

输入:people = [[7,0],[4,4],[7,1],[5,0],[6,1],[5,2]]
输出:[[5,0],[7,0],[5,2],[6,1],[4,4],[7,1]]
解释:
编号为 0 的人身高为 5 ,没有身高更高或者相同的人排在他前面。
编号为 1 的人身高为 7 ,没有身高更高或者相同的人排在他前面。
编号为 2 的人身高为 5 ,有 2 个身高更高或者相同的人排在他前面,即编号为 0 和 1 的人。
编号为 3 的人身高为 6 ,有 1 个身高更高或者相同的人排在他前面,即编号为 1 的人。
编号为 4 的人身高为 4 ,有 4 个身高更高或者相同的人排在他前面,即编号为 0、1、2、3 的人。
编号为 5 的人身高为 7 ,有 1 个身高更高或者相同的人排在他前面,即编号为 1 的人。
因此 [[5,0],[7,0],[5,2],[6,1],[4,4],[7,1]] 是重新构造后的队列。

示例 2:

输入:people = [[6,0],[5,0],[4,0],[3,2],[2,2],[1,4]]
输出:[[4,0],[5,0],[2,2],[3,2],[1,4],[6,0]]

提示:

  • 1 <= people.length <= 2000
  • 0 <= hi <= 106
  • 0 <= ki < people.length
  • 题目数据确保队列可以被重建

思路:

先排序,高个子排进去后,让个子矮的选位置。

代码:

class Solution {
public:vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {vector<vector<int>> v;sort(people.begin(),people.end(),[](const vector<int>& v1, const vector<int>& v2){return v1[0] > v2[0] || (v1[0]==v2[0]&&v1[1] < v2[1]);});for(int i=0;i<people.size();i++){v.insert(v.begin()+people[i][1],people[i]);}return v;}
};

http://www.jmfq.cn/news/5346181.html

相关文章:

  • 学校网站建设多少钱/seo研究协会
  • 崇明区建设镇政府网站/没有限制的国外搜索引擎
  • 新疆省建设厅官方网站/免费培训seo
  • 大连科技学院官方网站的建设与放/互联网营销培训课程
  • 4徐汇区网站建设/十大免费b2b网站
  • 辽宁建设考试培训网站/视频号视频怎么看下载链接
  • 哈尔滨网站建设哪家好而且价格不贵/医院线上预约
  • 佛山企业网站建设教程/博客网站登录入口
  • 网站建设详细的步骤有哪些/友情链接互换
  • 江苏昆山网站建设/百度渠道开户
  • 深圳建设工程质量安全智能监管平台网站/app拉新怎么做
  • 学校网站群建设设计/saas建站平台
  • 农商网站建设个人总结/站长之家seo工具包
  • 甘肃建设厅网站官网/国内十大搜索引擎
  • 建设工程项目在哪个网站查询/黄石seo诊断
  • 咸阳网站建设专业公司/qq空间秒赞秒评网站推广
  • 山东省建设厅网站多少/青岛seo推广专员
  • 京东网站建设的策划书/谷歌搜索引擎363入口
  • 珠海做网站建设/淘宝推广费用一般多少
  • 网站建设126/怎样制作一个网站
  • 网站正在建设中备案/今日重大事件
  • 龙山网站建设/seo优化自动点击软件
  • 佛山市住房和城乡建设委员会网站/兰州网络推广技术
  • 网站打开为建设中/企业宣传推广
  • 网站建设实训作业/上海短视频培训机构
  • 学校网站的建设目标是什么/google谷歌
  • 网站建设嘉兴/郑州全域静态管理
  • 马拉松网站建设/站长工具关键词排名怎么查
  • 网站建设领导讲话稿/百度seo排名软
  • 北京远程时代网站建设/百度站长中心