LeetCode.985-查询后偶数的总和(Sum of Even Numbers After Queries)
这是悦乐书的第370次更新,第398篇原创
01 看题和准备
今天介绍的是LeetCode
算法题中Easy
级别的第232
题(顺位题号是985
)。有一个整数数组A和一个查询数组queries。
对于第i个查询val = queries[i][0]
,index = queries[i][1]
,我们将val
添加到A[index]
。然后,第i
个查询的答案是A
的偶数值的总和。(这里给定的index = queries[i][1]
是一个基于0的索引,每个查询都会修改数组A
。)
返回所有查询的答案。你的答案数组answer
应该是answer[i]
作为第i
个查询的答案。例如:
输入:A = [1,2,3,4],queries = [[1,0],[-3,1],[-4,0],[2,3]]
输出:[8,6,2,4]
说明:一开始,数组是[1,2,3,4]。
在向A[0]
加1后,数组为[2,2,3,4],偶数值之和为2 + 2 + 4 = 8。
在向A[1]
加-3后,数组为[2,-1,3,4],偶数值之和为2 + 4 = 6。
在向A[0]
加上-4后,数组为[-2,-1,3,4],偶数值之和为-2 + 4 = 2。
在向A[3]
加2后,数组为[-2,-1,3,6],偶数值之和为-2 + 6 = 4。
注意:
1 <= A.length <= 10000
-10000 <= A[i] <= 10000
1 <= queries.length <= 10000
-10000 <= queries[i][0] <= 10000
0 <= queries[i][1] <A.length
02 第一种解法
直接翻译题目,找出queries
中对应的索引和val
,改变A中对应元素的的值,接着利用循环求A
中偶数元素的总和,赋值给结果数组result
。
此解法的时间复杂度为O(M*N)
,M
为queries
的长度,N
为A
的长度,空间复杂度为O(M)
,M
为queries
的长度。
public int[] sumEvenAfterQueries(int[] A, int[][] queries) {
int len = queries.length;
int[] result = new int[len];
for (int i=0; i<len; i++) {
A[queries[i][1]] += queries[i][0];
result[i] = evenSum(A);
}
return result;
}
public int evenSum(int[] A){
int sum = 0;
for (int num : A) {
if (num%2==0) {
sum += num;
}
}
return sum;
}
03 第二种解法
第一种解法的时间复杂度太高了,还可以再优化下。
结果数组中的值,后一位是在前一位的基础上产生的,主要判断A
中的当前位元素值、queries中
的值的奇偶性。拿题目给的示例来看,在第二次操作后,A
变成了[2,-1,3,4]
,将第一次操作后的数组A=[2,2,3,4]
中的第二个元素变成了-1,而第一次操作的偶数元素和是8,现在第二个元素变成了奇数,就需要将第一次加的2给减掉,所以第二次操作后的偶数和变成了8-2=6,剩下的几步操作都可以这样理解。
因此,我们就需要判断当前要操作的的A[i]
的奇偶和queries[i][0]
的奇偶,可以分为四种情况:
第一种情况:queries[i][0]
为偶数、A[i]
也为偶数,即前一次的求和中有A[i]
,只需加上queries[i][0]
的值即可,即sum = sum + queries[i][0]
。
第二种情况:queries[i][0]
为偶数、A[i]
为奇数,即前一次的求和中没有A[i]
,并且A[i]加上queries[i][0]
后也是奇数,所以不用更新sum
的值。
第三种情况:queries[i][0]
为奇数、A[i]
为偶数,即前一次的求和中有A[i]
,现在A[i]
加上queries[i][0]
后变成了奇数,需要将前一次求和中的A[i]
减掉,即sum = sum - A[i]
。
第四种情况:queries[i][0]
为奇数、A[i]
也为奇数,即前一次的求和中没有A[i]
,但是A[i]
加上queries[i][0]
后变成了偶数,需要把这个新的偶数加到sum
上,即sum = sum + queries[i][0] + A[i]
。
在计算完sum
的值后,将sum赋值给新数组对应位置元素,将ueries[i][0] + A[i]
的值赋值给A[i]
,最后返回结果数组。
此解法的时间复杂度为O(M)
,M
为queries
的长度,空间复杂度为O(M)
,M
为queries
的长度。
public int[] sumEvenAfterQueries2(int[] A, int[][] queries) {
int sum = 0, i = 0;
for (int num : A) {
if (num%2 == 0) {
sum += num;
}
}
int[] result = new int[queries.length];
for (int[] arr : queries) {
int curval = arr[0];
int preval = A[arr[1]];
// 做奇偶判断
if (curval%2 == 0) {
if (preval%2 == 0) {
sum = sum + curval;
}
} else {
if (preval%2 == 0) {
sum = sum - preval;
} else {
sum = sum + curval + preval;
}
}
A[arr[1]] += curval;
result[i++] = sum;
}
return result;
}
04小结
算法专题目前已连续日更超过七个月,算法题文章238+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。
以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!
LeetCode.985-查询后偶数的总和(Sum of Even Numbers After Queries)的更多相关文章
- 【LEETCODE】47、985. Sum of Even Numbers After Queries
package y2019.Algorithm.array; /** * @ProjectName: cutter-point * @Package: y2019.Algorithm.array * ...
- 【Leetcode_easy】985. Sum of Even Numbers After Queries
problem 985. Sum of Even Numbers After Queries class Solution { public: vector<int> sumEvenAft ...
- 【LeetCode】985. Sum of Even Numbers After Queries 解题报告(C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 暴力 找规律 日期 题目地址:https://lee ...
- 985. Sum of Even Numbers After Queries
We have an array A of integers, and an array queries of queries. For the i-th query val = queries[i] ...
- [Solution] 985. Sum of Even Numbers After Queries
Difficulty: Easy Question We have an array A of integers, and an array queries of queries. For the i ...
- [Swift]LeetCode985. 查询后的偶数和 | Sum of Even Numbers After Queries
We have an array A of integers, and an array queries of queries. For the i-th query val = queries[i] ...
- 【leetcode】985. Sum of Even Numbers After Queries
题目如下: We have an array A of integers, and an array queries of queries. For the i-th query val = quer ...
- #Leetcode# 985. Sum of Even Numbers After Queries
https://leetcode.com/problems/sum-of-even-numbers-after-queries/ We have an array A of integers, and ...
- LeetCode 985 Sum of Even Numbers After Queries 解题报告
题目要求 We have an array A of integers, and an array queries of queries. For the i-th query val = queri ...
随机推荐
- visudo修改编辑器vim
update-alternatives --config editor
- Java技术综述
自己打算好好学习下Java,所以想先明晰Java开发中到底有哪些技术,以便以后学习的过程中,可以循序渐进,随着学习的深入,本文将不断更新. Java基础教程将Java的入门基础知识贯穿在一个实例中,逐 ...
- "main" java.io.IOException: Mkdirs failed to create /user/centos/hbase-staging (exists=false, cwd=file:/home/centos)
Exception in thread "main" java.io.IOException: Mkdirs failed to create /user/centos/hbase ...
- grunt-css-sprite css 代码中的切片合并
安装插件:npm install grunt-css-sprite --save-dev grunt-css-sprite主要功能:1.对 css 文件进行处理,收集切片序列,生成雪碧图2.在原css ...
- myleecode
目录 # myleecode 1.冒泡排序 2.快速排序 3.进度条打印 4.打印 九九乘法表 5.打印 金字塔 6.接雨滴 7.一行代码实现1-100个数相加 8.如何在不使用内置方法强制转换的情况 ...
- sizeof运算符、虚函数、虚继承考点(待修改)
参考: http://blog.csdn.net/wangyangkobe/article/details/5951248 下面的文章解释有错误,不要看.......... 记住几句话: 编译器为每个 ...
- 自定义 Swiper 的上一页,下一页按钮
1. Swiper 的上一页,下一页按钮,不是必需包含在container 中的 2. 定义上一页,下一页按钮的样式,CSS略.... 3. 在初始化Swiper中,定义上一页,下一页按钮
- C# 遍历控件名称
List<string> list = new List<string>(); list.Add("textBox2"); list.Add("t ...
- head first 设计模式笔记7-适配器模式与外观模式
适配器模式:将一个类的接口,转换成客户期望的另一个接口.适配器让原本接口不兼容的类可以合作无间. 这个模式可以通过创建适配器进行接口转换,让不兼容的接口变成兼容.这可以让客户从实现的接口解耦.如果在一 ...
- JS框架_(JQuery.js)文章全屏动画切换
百度云盘 传送门 密码:anap 文章全屏动画切换效果 <!doctype html> <html lang="zh"> <head> < ...