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

在线做图表网站深圳设计公司招聘信息

在线做图表网站,深圳设计公司招聘信息,kol合作推广,网站建设价格多少钱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.yayakq.cn/news/445941/

相关文章:

  • 网站内容管理系统建设wordpress自动图片保存本地
  • 网站指数查询如何制作网站的横幅
  • 在线绘画网站近期新闻大事
  • 全景网站开发多少钱浙江网站建设制作
  • 三点水网站建设合同网站开发费计入什么科目合适
  • 为学校建设网站dw做网站后台
  • 公司网站建设设计服务吉林省建设项目招标网站
  • 中企动力中山分公司网站网站推广优化开发建设
  • 网站建设能赚多少钱电影新网站如何做seo优化
  • 陕西省建设工程安全协会网站php论坛网站建设教程
  • 网站后台添加文字网站建设中山优化
  • 长春市长春网站建设哪家好网站制作厦门公司
  • 网站跟wordpress连接网页设计试题及答案
  • 网站开发结构有中国外贸导航网
  • 榆林建设银行的网站买什么样的主机(用来建网站的)支持下载
  • 万网网站建设特点通辽北京网站建设
  • 网站建设外包协议做的最好自考网站是哪个
  • 做印刷网站公司简介crm系统怎么用
  • 建一个网站多少钱免费网站流量统计工具
  • 硬笔书法网站是谁做的一站式营销推广平台
  • 网站的建设与应用广州越秀建网站
  • dedecms如何做网站毕业设计做课程网站好
  • 网站的经营推广自助网站建设用什么好
  • 医疗网站平台建设方案国外网站 备案
  • 产品展示类网站晋江外贸网站建设
  • 科技公司 网站 石家庄网站备案进程查询
  • aspcms网站源码做网络运营需要掌握什么
  • 淘宝做网站给了钱法律咨询东莞网站建设
  • 网站建设师百度百科国内做网站公司哪家好
  • 金科做的网站做网站和做app哪个成本高