2023-06-02:给定一个二进制数组 nums 和一个整数 k,

k位翻转 就是从 nums 中选择一个长度为 k 的 子数组,

同时把子数组中的每一个 0 都改成 1 ,把子数组中的每一个 1 都改成 0。

返回数组中不存在 0 所需的最小 k位翻转 次数。如果不可能,则返回 -1。

子数组 是数组的 连续 部分。

输入:nums = [0,1,0], K = 1。

输出:2。

答案2023-06-02:

大体步骤如下:

1.初始化一个大小为 $n$ 的队列 queue,用于存储需要翻转的子数组的起始下标。

2.初始化三个变量 lrans 分别为 0,表示当前队列的左端点、右端点和翻转的次数。

3.循环遍历数组 nums 中的每个元素 num

  • 如果队列 queue 中存在元素,并且当前元素下标减去队列左端点下标等于 k,则说明队列中的第一个元素已经过期,将左端点右移一位。

  • 如果队列 queue 中的元素个数为奇数,并且当前元素与队列最后一个元素不同,则将当前元素下标加入队列尾部,同时将翻转次数 ans 加 1。

4.如果队列 queue 长度大于 0 且队列最后一个元素下标加 k 大于数组长度,则返回 -1 表示无法完成翻转;否则,返回翻转次数 ans

时间复杂度为 $O(n)$,其中 $n$ 是数组 nums 的长度。循环遍历一次数组 nums,每个元素最多会被加入或弹出队列一次,因此时间复杂度是线性的。

空间复杂度也是 $O(n)$,因为需要使用一个大小为 $n$ 的队列来存储需要翻转的子数组的下标。同时,由于只保存了子数组的起始下标,因此空间复杂度不会超过 $n$。需要注意的是,在 C 和 C++ 中,使用指针代替数组时需要手动分配和释放内存,因此还需要额外的空间来存储指向动态分配内存的指针。

go完整代码如下:

package main

import "fmt"

func minKBitFlips(nums []int, k int) int {
n := len(nums)
queue := make([]int, n)
l, r, ans := 0, 0, 0 for i := 0; i < n; i++ {
if l != r && i-queue[l] == k {
l++
}
if (r-l)%2 == 1 == (nums[i] == 1) {
queue[r] = i
r++
ans++
}
} if l != r && queue[r-1]+k > n {
return -1
}
return ans
} func main() {
nums := []int{0, 1, 0}
k := 1
result := minKBitFlips(nums, k)
fmt.Println("Result:", result)
}

rust语言完整代码如下:

fn min_k_bit_flips(nums: Vec<i32>, k: i32) -> i32 {
let n = nums.len();
let mut queue = vec![0; n];
let (mut l, mut r, mut ans) = (0, 0, 0); for i in 0..n {
if l != r && i - queue[l] == k as usize {
l += 1;
} if (r as i32 - l as i32) & 1 == nums[i] {
queue[r] = i;
r += 1;
ans += 1;
}
} return if l != r && queue[r - 1] + k as usize > n {
-1
} else {
ans
};
} fn main() {
let nums = vec![0, 1, 0];
let k = 1;
let result = min_k_bit_flips(nums, k);
println!("Result: {}", result);
}

c++完整代码如下:

#include <iostream>
#include <vector> using namespace std; int minKBitFlips(vector<int>& nums, int k) {
int n = nums.size();
vector<int> queue(n);
int l = 0, r = 0, ans = 0;
for (int i = 0; i < n; i++) {
if (l != r && i - queue[l] == k) {
l++;
}
if (((r - l) & 1) == nums[i]) {
queue[r++] = i;
ans++;
}
}
return (l != r && queue[r - 1] + k > n) ? -1 : ans;
} int main() {
vector<int> nums = { 0, 1, 0 };
int k = 1;
int result = minKBitFlips(nums, k);
cout << "Result: " << result << endl;
return 0;
}

c语言完整代码如下:

#include <stdio.h>
#include <stdlib.h> int minKBitFlips(int* nums, int numsSize, int k) {
int* queue = (int*)malloc(numsSize * sizeof(int));
int l = 0, r = 0, ans = 0;
for (int i = 0; i < numsSize; i++) {
if (l != r && i - queue[l] == k) {
l++;
}
if (((r - l) & 1) == nums[i]) {
queue[r++] = i;
ans++;
}
}
free(queue);
return (l != r && queue[r - 1] + k > numsSize) ? -1 : ans;
} int main() {
int nums[] = { 0, 1, 0 };
int numsSize = sizeof(nums) / sizeof(nums[0]);
int k = 1;
int result = minKBitFlips(nums, numsSize, k);
printf("Result: %d\n", result);
return 0;
}

2023-06-02:给定一个二进制数组 nums 和一个整数 k, k位翻转 就是从 nums 中选择一个长度为 k 的 子数组, 同时把子数组中的每一个 0 都改成 1 ,把子数组中的每一个 1的更多相关文章

  1. 当在myeclipse里发送邮件有错误时,不妨把环境都改成jdk的

    当在myeclipse里发送邮件有错误时,不妨把环境都改成jdk的, 如果是jre的环境会出错,改成jdk的就行了.

  2. zf-关于查询机把index.jsp换成index_new.jsp页面之后把功能链接都改成新页面的简单方法

    一开始我都是找action 然后一个一个的改 把onmousedown="goURL('index.jsp')" 改成 onmousedown="goURL('index ...

  3. 复利计算5.0(改成Java版本)与 单元测试

    //由于C语言版本不方便单元测试,所以改成了java版本,部分代码如下:import java.util.Scanner; public class FuLi{ public static void ...

  4. 73. Set Matrix Zeroes 把矩阵同一行列的元素都改成0

    [抄题]: Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in-place. ...

  5. 为什么很多第三方接口,都改成了基于http,直接传递json数据的方式来代替webservice?

    这实际上是三个问题,从WebService到今天流行的RESTful API(JSON) over HTTP,经历了数次变革 1 WebService有很多协议,为什么HTTP比较流行? WebSer ...

  6. 【LeetCode】1461. 检查一个字符串是否包含所有长度为 K 的二进制子串 Check If a String Contains All Binary Codes of Size K

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 统计长度为 K 的子串个数 日期 题目地址:https ...

  7. MFC下debug改成release版本出现问题及解决办法

    自己在debug下成功运行了自己写的测试自己写第三方库的程序,这里有用到opencv库,所以同时用到了自己的库和opencv的库,需求因为要进行速度的测试,是想要把debug改成release版本,这 ...

  8. sqlserver服务器名称改成本地IP地址登录

    在安装sqlserver2008.2012等时选择的是默认实例,服务器名称也就是电脑的名称,特别是登录本地的数据库,需要输入电脑用户名称加上SQLEXPRESS 例如:zhangsan\SQLEXPR ...

  9. mysql数据库使用sql命令窗口查询的数据,改成sql语句导入到mysql数据库中

    1.查询语句为select * from t_table;导出的数据格式如下: 2.将数据文本备份,然后使用NOTEPAD++打开,然后只拷贝数据到新建txt中,然后进行如下替换: 1)将“ | ”分 ...

  10. AutoCAD如何方便截图放到Word文档,改成白底黑字

    将模型视图切换到布局2即可   比如下图所示的效果   先回到模型视图把所有线条颜色都改成白色,然后添加适当的标注(比如要受力分析,则在CAD中绘制箭头也很方便的),文字说明.然后切换到布局2就OK ...

随机推荐

  1. java异常--自定义异常

    java异常--自定义异常 步骤: 创建自定义异常类. 在方法中通过throw关键字抛出异常对象. 处理异常try-catch 捕获并处理,否则在方法声明处通过throws关键字指明抛出给调用者的方法 ...

  2. Java面试——JVM知识

    一.什么情况下会发生栈内存溢出 [1]线程请求的栈深度大于虚拟机所允许的深度,将抛出 StackOverflowError 异常.递归的调用一个简单的方法,不断累积就会抛出 StackOverflow ...

  3. SpringBoot打包成exe(别再用exe4j了,使用JDK自带工具)

    SpringBoot打包成exe(别再用exe4j了,使用JDK自带工具) 搜到大部分打包exe的文章都是使用exe4j打包 步骤贼多,安装麻烦,打包麻烦 收费软件,公司使用会吃律师函 JDK14以上 ...

  4. PDD也可以通过ID获取商品详情?

    先我们可以通过pinduoduo.item_get的接口传入商品的ID参数,这个接口可以获取到拼多多商品的详情数据,包括商品的标题.价格.原价.卖家的昵称.库存.销量.宝贝的链接.商品的备注.宝贝图片 ...

  5. 二进制安装Kubernetes(k8s) v1.23.4

    1.环境 网段 物理主机:192.168.1.0/24 service:10.96.0.0/12 pod:172.16.0.0/12 如果有条件建议k8s集群与etcd集群分开安装 1.1.k8s基础 ...

  6. flask配置config详解

    flask系列讲座与2017年12月6日开始,每周一篇.第三篇其中讲述flask的配置方法.使用app.config.from_object()方法,似乎很神奇.如果明白背后逻辑,实际上很自然.涉及代 ...

  7. [数据库]mysql/mysqldump命令帮助说明

    1 mysql [root@test ~]# mysql --help mysql Ver 14.14 Distrib 5.7.24-27, for Linux (x86_64) using 6.0 ...

  8. 生成df的几种方法

    法一: pd.DataFrame( [ (第一行),(第二行),(第三行)] ) df = pd.DataFrame([('bird', 389.0), ('bird', 24.0), ('mamma ...

  9. prometheus node-exporter安装

    目录 prometheus node-exporter安装 包安装在linux服务器 Daemonset安装 Docker安装 helm安装 prometheus node-exporter安装 安装 ...

  10. Network Science: 巴拉巴西网络科学阅读笔记

    前言: 最小生成树中Kruskal算法对应了统计物理中的著名模型invasion percolation.由此写了一篇文章:invasion percolation and global optimi ...