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

安徽省建设厅到底哪个网站纹身网站设计

安徽省建设厅到底哪个网站,纹身网站设计,十堰seo,阿里云主机 多个网站leetcode 1005. K 次取反后最大化的数组和 1005. K 次取反后最大化的数组和 给你一个整数数组 nums 和一个整数 k ,按以下方法修改该数组: 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以…

leetcode 1005. K 次取反后最大化的数组和

1005. K 次取反后最大化的数组和

给你一个整数数组 nums 和一个整数 k ,按以下方法修改该数组:

  • 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。

重复这个过程恰好 k 次。可以多次选择同一个下标 i 。

以这种方式修改数组后,返回数组 可能的最大和 。

示例 1:

输入:nums = [4,2,3], k = 1
输出:5
解释:选择下标 1 ,nums 变为 [4,-2,3] 。

示例 2:

输入:nums = [3,-1,0,2], k = 3
输出:6
解释:选择下标 (1, 2, 2) ,nums 变为 [3,1,0,2] 。

示例 3:

输入:nums = [2,-3,-1,5,-4], k = 2
输出:13
解释:选择下标 (1, 4) ,nums 变为 [2,3,-1,5,4] 。

代码 

// leetcode 1005. K 次取反后最大化的数组和
// 先排序把负数取反
// 如果负数全部取反之后还没到k次 就重新排序只取反最小值
class Solution {
public:int largestSumAfterKNegations(vector<int>& nums, int k) {sort(nums.begin(), nums.end());for (int i = 0; i < nums.size() && k > 0; ++i){if (nums[i] >= 0){break;}nums[i] *= -1;k--;}sort(nums.begin(), nums.end());int result = 0;if (k == 0 || k % 2 == 0){result = nums[0];}else{result = -1 * nums[0];}for (int i = 1; i < nums.size(); ++i){result += nums[i];}return result;}
};// 代码随想录的版本,比我的轻量的多,我这边有两次排序,卡尔的只需要第一次按绝对值排序即可
class Solution {static bool cmp(int a, int b) {return abs(a) > abs(b);}
public:int largestSumAfterKNegations(vector<int>& A, int K) {sort(A.begin(), A.end(), cmp);       // 第一步for (int i = 0; i < A.size(); i++) { // 第二步if (A[i] < 0 && K > 0) {A[i] *= -1;K--;}}if (K % 2 == 1) A[A.size() - 1] *= -1; // 第三步int result = 0;for (int a : A) result += a;        // 第四步return result;}
};

leetcode 134. 加油站

134. 加油站

在一条环路上有 n 个加油站,其中第 i 个加油站有汽油 gas[i] 升。

你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发,开始时油箱为空。

给定两个整数数组 gas 和 cost ,如果你可以绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1 。如果存在解,则 保证 它是 唯一 的。

示例 1:

输入: gas = [1,2,3,4,5], cost = [3,4,5,1,2]
输出: 3
解释:
从 3 号加油站(索引为 3 处)出发,可获得 4 升汽油。此时油箱有 = 0 + 4 = 4 升汽油
开往 4 号加油站,此时油箱有 4 - 1 + 5 = 8 升汽油
开往 0 号加油站,此时油箱有 8 - 2 + 1 = 7 升汽油
开往 1 号加油站,此时油箱有 7 - 3 + 2 = 6 升汽油
开往 2 号加油站,此时油箱有 6 - 4 + 3 = 5 升汽油
开往 3 号加油站,你需要消耗 5 升汽油,正好足够你返回到 3 号加油站。
因此,3 可为起始索引。

示例 2:

输入: gas = [2,3,4], cost = [3,4,3]
输出: -1
解释:
你不能从 0 号或 1 号加油站出发,因为没有足够的汽油可以让你行驶到下一个加油站。
我们从 2 号加油站出发,可以获得 4 升汽油。 此时油箱有 = 0 + 4 = 4 升汽油
开往 0 号加油站,此时油箱有 4 - 3 + 2 = 3 升汽油
开往 1 号加油站,此时油箱有 3 - 3 + 3 = 3 升汽油
你无法返回 2 号加油站,因为返程需要消耗 4 升汽油,但是你的油箱只有 3 升汽油。
因此,无论怎样,你都不可能绕环路行驶一周。

代码 

// leetcode 134. 加油站// 暴力解法 但是暴力是超时的
// 遍历找到第一个cost[i] <= gas[i]的索引然后遍历 
class Solution {
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int size = cost.size();for (int i = 0; i < size; ++i){int rest = gas[i] - cost[i];int index = (i + 1) % size;while (rest >= 0 && index != i){rest += gas[index] - cost[index];index = (index + 1) % size;}if (rest >= 0 && index == i){return i;}}return -1;}
};// 贪心算法
// 保存 gas - cost
class Solution {
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int curSum = 0;int totalSum = 0;int result = 0;for (int i = 0; i < gas.size(); ++i){int rest = gas[i] - cost[i];curSum += rest;totalSum += rest;if (curSum < 0){result = i + 1;curSum = 0;}}if (totalSum < 0){return -1;}return result;}
};

http://www.hrbkazy.com/news/27160.html

相关文章:

  • 温州做网络推广的公司点击宝seo
  • 服务器搭建网站空间内部优化
  • 做rom的网站软文是什么东西
  • 做美团类似的网站营销技巧培训
  • 网站用户体验改善的好处百度营销
  • 企业邮箱注册需要多少钱seo优化排名易下拉软件
  • 高端网站建设推来客地址搜索引擎推广简称
  • 安监局网站做应急预案备案百度经验发布平台
  • 织梦dedecms绿色led照明公司企业网站模板 下载seo是哪个英文的简写
  • 合肥网站设计建设八上数学优化设计答案
  • 前端网站开发流程图企业的网络推广
  • 自己做网站好还是让别人做知道百度
  • 网站服务器在哪里网络营销常用的工具和方法
  • 毕业设计做网站代码安徽seo
  • 做网站开发找哪家公司今天特大新闻最新消息
  • 网站定制公司哪家最权威中国十大网站排名
  • 专业做网站建设公司河南省干部任免最新公示
  • 网站seo优化关键词网站推广的营销策划方案
  • 自己做网站怎么优化seo优化文章网站
  • 凡科网做网站好吗怎么去推广自己的产品
  • 营销推广小程序有哪些优化设计电子课本
  • 找别人建个网站多少钱企业培训内容有哪些
  • WordPress指定IP访问长沙seo就选智优营家
  • 个人做电子商务网站 今日头条
  • 建设部网站在哪里报名考试群站优化之链轮模式
  • 什么网站做班服比较好班级优化大师官方免费下载
  • 公司名注册网络优化培训骗局
  • 网站运营专员是干嘛的如何制作一个公司网站
  • 零基础学做网站页微信引流的十个方法
  • 写作网站签约都要上传身份证吗seo快速排名优化公司