2023-04-22:给你两个正整数数组 nums 和 target ,两个数组长度相等。 在一次操作中,你可以选择两个 不同 的下标 i 和 j , 其中 0 <= i, j < nums.leng
2023-04-22:给你两个正整数数组 nums 和 target ,两个数组长度相等。
在一次操作中,你可以选择两个 不同 的下标 i 和 j ,
其中 0 <= i, j < nums.length ,并且:
令 nums[i] = nums[i] + 2 且
令 nums[j] = nums[j] - 2 。
如果两个数组中每个元素出现的频率相等,我们称两个数组是 相似 的。
请你返回将 nums 变得与 target 相似的最少操作次数。
测试数据保证 nums 一定能变得与 target 相似。
输入:nums = [8,12,6], target = [2,14,10]。
输出:2。
答案2022-04-22:
给定两个长度相等的整型数组 nums 和 target,要求将 nums 变为与 target 相似,并返回最少需要的操作次数。
具体地,每一次操作可以选择两个下标 i 和 j,并满足以下条件:
0 <= i,j < nums.lengthnums[i] = nums[i] + 2,nums[j] = nums[j] - 2
操作后,需要检查变换后的 nums 是否与 target 频率相等。如果是,则称 nums 与 target 是相似的,返回此时的操作次数。
按照题目描述实现过程可以分为以下几个步骤:
- 统计
nums和target中所有元素出现的频率,然后比较两者是否相同。由于题目保证了nums可以变为target相似,因此这一步可以省略。 - 对
nums和target进行奇偶数值分离,将奇数值从偶数值中分离出来。这一步可以使用split()函数实现。 - 对
nums和target分别对奇数值和偶数值进行排序。这里可以使用sort.Ints()函数进行排序。 - 逐一比较
nums和target中的对应元素,计算它们之间的差值的绝对值之和。这一步可以使用abs()函数和循环实现。 - 将差值的绝对值之和除以 4,即得到最少操作次数。
整个过程就是这样。具体来说,第二步和第三步是为了方便后面的比较和计算而进行的预处理。第四步是最重要的一步,需要仔细计算每一个位置上的差值,并将它们相加。第五步只是简单的除法运算,将计算结果转化为操作次数即可。
时间复杂度:
- 对于奇偶数值分离的操作,需要遍历一遍数组,时间复杂度为
O
(
n
)
O(n)
O(n);
- 对于排序操作和差值计算操作,需要遍历两次长度为
n
n
n 的数组,时间复杂度为
O
(
n
log
n
)
O(n \log n)
O(nlogn);
- 因此,总的时间复杂度为
O
(
n
log
n
)
O(n \log n)
O(nlogn)。
空间复杂度:
- 变量
numsOddSize、line和ans占用常数级别的空间,不随输入规模变化,因此空间复杂度为 O(1); - 函数中使用了
sort.Ints()函数进行排序,该函数使用了快速排序算法,在最坏情况下需要递归调用 log_2(n) 层,空间复杂度为 O(log n); - 因此,总的空间复杂度为 O\log n)。
综上所述,该算法的时间复杂度为 O(n log n),空间复杂度为 O(log n)。
go完整代码如下:
package main
import (
"fmt"
"sort"
)
func makeSimilar(nums, target []int) int64 {
n := len(nums)
numsOddSize := split(nums)
split(target)
sort.Ints(nums[:numsOddSize])
sort.Ints(nums[numsOddSize:])
sort.Ints(target[:numsOddSize])
sort.Ints(target[numsOddSize:])
var ans int64
for i := 0; i < n; i++ {
ans += int64(abs(nums[i] - target[i]))
}
return ans >> 2
}
func split(arr []int) int {
line := 0
for i := 0; i < len(arr); i++ {
if arr[i]&1 != 0 {
swap(arr, i, line)
line++
}
}
return line
}
func swap(arr []int, i, j int) {
tmp := arr[i]
arr[i] = arr[j]
arr[j] = tmp
}
func abs(x int) int {
if x < 0 {
return -x
}
return x
}
func main() {
nums := []int{8, 12, 6}
target := []int{2, 14, 10}
ans := makeSimilar(nums, target)
fmt.Println(ans)
}

rust完整代码如下:
fn make_similar(nums: Vec<i32>, target: Vec<i32>) -> i64 {
let n = nums.len();
let mut nums = nums;
let mut target = target;
let odd_size = split(&mut nums);
split(&mut target);
nums[..odd_size].sort_unstable();
nums[odd_size..n].sort_unstable();
target[..odd_size].sort_unstable();
target[odd_size..n].sort_unstable();
let mut ans = 0;
for i in 0..n {
ans += (nums[i] - target[i]).abs() as i64;
}
ans >> 2
}
fn split(arr: &mut [i32]) -> usize {
let mut line = 0;
for i in 0..arr.len() {
if arr[i] & 1 != 0 {
arr.swap(i, line);
line += 1;
}
}
line
}
fn main() {
let nums = vec![8, 12, 6];
let target = vec![2, 14, 10];
let ans = make_similar(nums, target);
println!("{}", ans);
}

2023-04-22:给你两个正整数数组 nums 和 target ,两个数组长度相等。 在一次操作中,你可以选择两个 不同 的下标 i 和 j , 其中 0 <= i, j < nums.leng的更多相关文章
- 输入两个正整数m和n,求其最大公约数和最小公倍数
public static void main(String[] args){ Scanner sc = new Scanner (System.in); int a,b; System.out ...
- LeetCode 周赛 342(2023/04/23)容斥原理、计数排序、滑动窗口、子数组 GCB
本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 大家好,我是小彭. 前天刚举办 2023 年力扣杯个人 SOLO 赛,昨天周赛就出了一场 Easy - Ea ...
- 一个数组nums,其中任意两个值等于给定值target,返回这两个值在nums里的位置
package com.java.tencent; import java.lang.reflect.Array; import java.util.Arrays; import java.util. ...
- Ubuntu20.04/22.04 安装 Arduino IDE 2.x
这周收到两片基于LGT8F328P LQFP32的Arduino Mini EVB, 机器上没有 Arduino 环境需要新安装, 正好感受一下新出的 Arduino IDE 2.x, 记录一下 Ub ...
- C语言实验报告(五) 两个正整数的最大公约数
编程实现求两个正整数的最大公约数,要求计算最大公约数用函数fun(int a,int b)实现. #include<stdio.h>void main(){ int n,a,b; in ...
- SDUT 3503 有两个正整数,求N!的K进制的位数
有两个正整数,求N!的K进制的位数 题目链接:action=showproblem&problemid=3503">http://sdutacm.org/sdutoj/prob ...
- 代码代码:输入两个正整数m和n,求其最大公约数和最小公倍数。15 20 5
import java.util.Scanner; //输入两个正整数m和n,求其最大公约数和最小公倍数.15 20 5 public class Test { public static void ...
- 今天遇到的面试题for(j=0,i=0;j<6,i<10;j++,i++) { k=i+j; } k 值最后是多少?
for(j=0,i=0;j<6,i<10;j++,i++) { k=i+j; } k 值最后是多少? <script type="text/javascript" ...
- http://www.blogjava.net/crespochen/archive/2011/04/22/348819.html
http://blog.csdn.net/supersky07/article/details/7407523 http://blog.csdn.net/cuker919/article/detail ...
- 输入两个正整数num1、num2,计算并输出它们的和、差、积、整数商和余数
课本例题 /*输入两个正整数num1.num2,计算并输出它们的和.差.积.整数商和余数.*/ #include<stdio.h> int main() { int num1, num2; ...
随机推荐
- Adams:一种使接触力(力矩等等)失效的方法
1 第一步:点击"运行脚本". 2 第二步:右击选择"仿真脚本",点击"创建". 3 第三步:选择"脚本类型"为&quo ...
- 在.net core中开发web页面,更新html代码刷新不生效的问题
因为在.net core之后的版本,程序都是以控制台应用程序的方式存在,所以一些老的项目升级后,会出现这样的情况, 解决方法,在nuget中引入 Microsoft.AspNetCore.Mvc.Ra ...
- Java 题目集 编程
7-1 多数组排序 (20 分) 3个整数数组进行整体排序,根据输入的三个数组的元素,输出排序后的结果(从大到小) 输入格式: 第1个数组的长度 第1个数组的各个元素 第2个数组的长度 第2个数组 ...
- unidbgrid默认列排序
UniDBGrid -> ClientEvents -> ExtEvents ->... function reconfigure(sender, store, columns, o ...
- spring-boot-starter-webflux
webflux: 反应式编程reactor的产物,采用发布订阅模式,引入netty的nio,比较适合IO密集型应用. 因普遍应用使用的DB链接是IO阻塞型,因此在一般应用中无法体现它的优势.redis ...
- Glist 按钮属性
grayed 变灰与否不影响点击等事件 touchable 为false,不会变灰,但会无法点击, enabled为false自动变灰,且无法点击
- 多线程中使用COM 的注意事项
最近做了一个TCP Server的程序,其中需用使用COM组件,但是tcp 的部分是阻塞的,所以开了一个线程用来专门接收来自客户端的信号,当接收到信号后,再根据情况处理. 按照这个思路,在程序的一开始 ...
- DVWA-Weak Session IDs(弱会话ID) 不安全的会话
在登录服务器之后,服务器会返回给用户一个会话(session),这个会话只会存在一段时间,拥有这个会话下次登录就不用输入密码就可以登录到网站,如果返回的这个会话很弱,容易被猜解到,就很不安全,照成会话 ...
- CF859E题解
题意简述 翻译很清楚了 题目解法 如果一个人想去的位置上原来坐着人,那么他要坐到这个位置上,就要把原来的人赶走. 原来的人被赶走了,就只能去想去的位置.如果那个位置上有人,又要把那个人赶走. 我们发现 ...
- Windows系统下Dos命令记录
# 切换到F:\test\目录 /d 参数可以直接切换,不需要先切换盘符 cd /d F:\test\ # 创建文件夹test md tset # 删除文件夹test rd test # 创建文件te ...