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. Spring MVC 和 Struts 的区别是什么?

    1. 拦截机制的不同 Struts2 是类级别的拦截,每次请求就会创建一个 Action,和 Spring 整合时 Struts2 的 ActionBean 注入作用域是原型模式 prototype, ...

  2. Solon v2.2.6 发布,助力信创国产化

    Solon 是一个高效的 Java 应用开发框架:更快.更小.更简单.它是一个有自己接口标准规范的开放生态,可为应用软件国产化提供支持,助力信创建设. 150来个生态插件,覆盖各种不同的应用开发场景: ...

  3. CentOS8安装Oracle datebase 19C

        我这里安装Oracle数据库是rpm格式的包.需要先得有以下依赖包关系,先依次按此顺序安装. yum install ./compat-libcap1-1.10-7.el7.x86_64.rp ...

  4. .NET Core MongoDB数据仓储和工作单元模式封装

    前言 上一章我们把系统所需要的MongoDB集合设计好了,这一章我们的主要任务是使用.NET Core应用程序连接MongoDB并且封装MongoDB数据仓储和工作单元模式,因为本章内容涵盖的有点多关 ...

  5. MQTT(EMQX) - SpringBoot 整合MQTT 连接池 Demo - 附源代码 + 在线客服聊天架构图

    MQTT(EMQX) - Linux CentOS Docker 安装 MQTT 概述 MQTT (Message Queue Telemetry Transport) 是一个轻量级传输协议,它被设计 ...

  6. Golang 常用库之jwt-go

    本文地址 https://www.cnblogs.com/zichliang/p/17303759.html github地址:https://github.com/dgrijalva/jwt-go ...

  7. windows10设置共享目录

    win10设置目录局域网内共享 1.右键点击文件属性,点击共享 2.选择与其共享的用户 3.点击共享,选择everyone,可以让在同一局域网下的用户访问 4.显示你的文件夹已共享 5.在同一局域网的 ...

  8. .Net Core工作流WorkFlowCore

    前言 WorkFlowCore是一个针对.NetCore的轻量级的工作流引擎,提供了FluentAPI.多任务.持久化以及并行处理的功能,适合于小型工作流.责任链的需求开发.支持工作流长期运行,提供了 ...

  9. 手把手逐步解析Javaweb登录实例

    一.编写前端界面 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  10. 【对比】文心一言对飚ChatGPT实操对比体验

    前言 缘由 百度[文心一言]体验申请通过 本狗中午干饭时,天降短信,告知可以体验文心一言,苦等一个月的实操终于到来.心中这好奇的对比心理油然而生,到底是老美的[ChatGPT]厉害,还是咱度娘的[文心 ...