(leetcode)66. 加一 67. 二进制求和(详解)

news2024/12/28 20:19:21

目录

66. 加一 

思路

代码

67. 二进制求和 

思路

代码


 

66. 加一 

给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。

最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。

你可以假设除了整数 0 之外,这个整数不会以零开头。

示例 1:

输入:digits = [1,2,3]
输出:[1,2,4]
解释:输入数组表示数字 123。
示例 2:

输入:digits = [4,3,2,1]
输出:[4,3,2,2]
解释:输入数组表示数字 4321。
示例 3:

输入:digits = [0]
输出:[1]
 

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/plus-one

思路

我们要先理解题意,这个就是把传上来的数组看成一个数

比如 [4,3,2,1],就是4321,然后在这个数的基础上加一,变成4322,然后再把加一后的数再转为数组,变成[4,3,2,2]

那这样的话我们就不得不考虑进位情况(如[9,9] --> 99 --> +1 --> 100 --> [1,0,0])

一.

1.那我们就要先创建一个空间来存放新数组了 ,因为存在进位情况(如99),所以位置要比原数组多一个位置(digitsSize + 1)

2.然后别忘记敲上此时的返回个数(先来进位情况)

3.那我们先把整体数组赋到新的空间里,记得把p[0]位留出来(留着放进位)(下边两种循环都可)

   ps:(i 要从0开始哦,因为是把digits数组放到p里,i 主要代表digits的下标)

 

 二.

1.p[0] 处先赋值上0

2.因为是从后面加,所以下标从后来(i = digitsSize)

3.p[i] = (p[i] + 1)%10  这一步完成题目要求的加一

 解释:

如果p[i] < 9,那(p[i] + 1)%10就大于0,直接结束循环(没进位),

如果p[i] == 9,p[i] + 1 = 10 % 10 == 0; 然后p[i]就得0,往下判断,继续进行循环(i --),直到循环结束或break跳出循环。

如果是类似99这样的情况,那就会一直走到p[0]那位,(p[0]+1)%10==1; 这就是进位占了多出的那位(p[0]这位放的0别忘了)

 

 三.

1.现在考虑一下没进位占p[0]位的情况(p[0]处依旧得0时)

2.返回个数变了(如下代码图)

3.就是把p数组整体往前挪一位

4.p最后多出的那一位保险起见放上‘\0’(不放不影响你过)

 

代码

int* plusOne(int* digits, int digitsSize, int* returnSize)
{
    int* p = (int*)malloc(sizeof(int)*(digitsSize + 1));
    int i = 0;
    *returnSize = digitsSize + 1;
    for(i = digitsSize - 1; i >= 0; i--)
    {
        p[i + 1] = digits[i];//新数组把原数组整体都向后挪一位,p[0]==0;因为有99这样的可能,变100;
    }
    p[0] = 0;
    for(i = digitsSize; i >= 0; i--)
    {
        p[i] = (p[i] + 1)%10;//如果是类似99这样的情况,那就会一直走到p[0]那位,
                             //(p[0]+1)%10==1;
        if(p[i] == 0)
        {
            continue;
        }
        else
        {
            break;
        }
    }
    if(p[0] == 0)
    {
        *returnSize = digitsSize;
        for(i = 0; i < digitsSize; i++)
        {
            p[i] = p[i+1];//没进位时,就把数组挪回来,把p[0]占了,不空0了
        }
        p[i] = '\0';
    }
    return p;
    free(p);
    p = NULL;
}

 

 

67. 二进制求和 

给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。

示例 1:

输入:a = "11", b = "1"
输出:"100"
示例 2:

输入:a = "1010", b = "1011"
输出:"10101"
 

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/add-binary

思路

上边的能懂的这个基本能懂,代码里都有注释 ,有看不懂的可以在评论区里问,或者私信,我都会回哦

 

 

代码

char* addBinary(char* a, char* b)
{
    int len1 = strlen(a);
    int len2 = strlen(b);
    int L = (len1 > len2) ? len1 : len2;
    int max = L + 2;//包括了进位和'\0'
    int ai = len1 - 1;//都从末位开始
    int bi = len2 - 1;
    int k = max - 2;//新数组有多进位(比原来的多一位时)时的下标(最后面的数的下标)
    char* p = (char*)malloc(sizeof(char) * max);//给新数组创位置
    p[max - 1] = '\0';//末位赋'\0'
    p[0] = '0';
    int flag = 0;//控制进位
    while (ai >= 0 || bi >= 0)
    {
        //转成整型计算
        int num1 = (ai >= 0) ? (a[ai] - '0') : 0;
        int num2 = (bi >= 0) ? (b[bi] - '0') : 0;
        int sum = num1 + num2 + flag;
        p[k] = sum % 2 + '0';//形成新数组了
        flag = sum / 2;//二进制得2进1
        ai--;
        bi--;
        k--;
    }
    if (flag != 0)//此时就还得进位
    {
        p[k] = '1';
    }
    if (p[0] == '1')
    {
        return p;//p[0]是1,就表明进位了,把p空间占满了,从头返回就行
    }
    else//否则就从p下标1位开始返回(因为没进位,p[0]空的,不要)
    {
        return p + 1;
    }
    free(p);
    p = NULL;
}

 

 

╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯完╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯╰(*°▽°*)╯

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/492960.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

7个最好的WordPress LMS在线学习管理系统比较

您是否正在为您的 WordPress 网站寻找最好的 LMS 在线学习管理系统插件&#xff1f; 学习管理系统 (LMS) 插件允许您创建和运行类似 Udemy 和 LearnDesk 等在线课程。一个完美的 WordPress LMS 插件拥有您管理在线课程、运行和评分测验、接受付款等所需的一切。 在本文中&…

【MySql】数据库 select 进阶

数据库 数据库表的设计ER 关系图三大范式 聚合函数与分组查询聚合函数 (count、sum、avg、max、min)分组查询 group by fields....having....(条件) 多表联查内连接外连接&#xff08;左连接&#xff0c;右连接&#xff09;自连接子查询合并查询 UNION 数据库表的设计 ER 关系…

在Centos中metabase安装与配置(bi工具)

1 metabase介绍 metabase是一款开源的BI分析工具&#xff0c;开发语言clojureReact为主、也有高阶的收费版。 官网&#xff1a;https://www.metabase.com/ 可以利用Metabase进行数据分析&#xff0c;数据可视化&#xff0c;报表生成等。开源地址&#xff1a;https://github.co…

(五)【平衡小车制作】位置式PID、直立环与速度环概念

声明&#xff1a;本博客是B站视频【天下行走的平衡小车视频】的笔记 一、PID控制算法概念 PID控制&#xff0c;即为对偏差进行比例、积分和微分控制。由三个元素构成:比例&#xff08;P&#xff09;&#xff0c;积分&#xff08;I&#xff09;&#xff0c;微分&#xff08;D&…

Linux系统应用编程(六)Linux网络编程(下篇)

本篇主要内容&#xff1a; 一、Linux的文件描述符二、多路IO转接&#xff08;上&#xff09;1.基础版多路IO转接select▶ 关于select( )函数▶ select( )改写上篇案例 2.加强版多路IO转接poll3.顶配版多路IO转接epoll▶ epoll相关函数&#xff08;1&#xff09;创建监听红黑树&…

重装系统后,MySQL install错误,找不到dll文件,或者应用程序错误

文章目录 1.找不到某某dll文件2.mysqld.exe - 应用程序错误使用DX工具直接修复 1.找不到某某dll文件 由于找不到VCRUNTIME140_1.dll或者MSVCP120.dll&#xff0c;无法继续执行代码&#xff0c;重新安装程序可能会解决此问题。 在使用一台重装系统过的电脑&#xff0c;再次重新…

Yolov8实战:交通roadsign识别,通过加入CVPR203 DCNV3和BiLevelRoutingAttention,暴力涨点

1.roadsign数据集介绍 数据集大小&#xff1a;877张 类别&#xff1a;speedlimit、crosswalk、trafficlight、stop 2.基于YOLOV8的roadsign识别 2.1 原始yolov8性能分析 原始map为0.841 2.1 加入DCNV3 博客地址&#xff1a; https://cv2023.blog.csdn.net/article/detai…

手写 EventBus:从零到一实现自己的事件总线库

简介&#xff1a;在本文中&#xff0c;我们将详细介绍如何从头开始实现一个轻量级的 EventBus 库。我们将以 XEventBus 为例&#xff0c;阐述整个实现过程&#xff0c;以及在实现过程中遇到的关键问题和解决方法。 一 引言 什么是 EventBus&#xff1f; EventBus 是一个基于…

C++ 多线程编程(三) 获取线程的返回值——future

C11标准库增加了获取线程返回值的方法&#xff0c;头文件为<future>&#xff0c;主要包括future、promise、packaged_task、async四个类。 那么&#xff0c;了解一下各个类的构成以及功能。 1 future future是一个模板类&#xff0c;它是传输线程返回值&#xff08;也…

2-Lampiao百个靶机渗透(精写-思路为主)框架漏洞利用2

特别注明&#xff1a;本文章只用于学习交流&#xff0c;不可用来从事违法犯罪活动&#xff0c;如使用者用来从事违法犯罪行为&#xff0c;一切与作者无关。 文章目录 前言一、环境重新部署二、AWVSxray联动和xraybs联动1.安装AWVSxray2.让xray和bs先联动3.AWVS和xray联动 三、p…

【Spring框架全系列】如何创建一个SpringBoot项目

&#x1f307;哈喽&#xff0c;大家好&#xff0c;我是小浪。前几篇博客我们已经介绍了什么是Spring&#xff0c;以及如何创建一个Spring项目&#xff0c;OK&#xff0c;那么单单掌握Spring是完全不够的&#xff0c;Spring的家族体系十分强大&#xff0c;我们还需要深入学习&am…

力扣---LeetCode160. 相交链表(代码详解+流程图)

文章目录 前言160. 相交链表链接&#xff1a;思路&#xff1a;方法一&#xff1a;暴力求解法1.1 时间复杂度&#xff1a;O(M*N)1.2 代码&#xff1a; 方法二&#xff1a;双指针2.1 时间复杂度&#xff1a;O(N)2.2 代码&#xff1a;2. 3流程图&#xff1a; 注意&#xff1a;补充…

13. Transformer(下)

P33 Transformer&#xff08;下&#xff09; 视频链接 P33 Transformer&#xff08;下&#xff09; 1. Decoder: Autoregressive(AT) Decoder原理&#xff1a; Encoder vs Decoder&#xff1a; Masked&#xff1a; how to stop&#xff1a; 2. Decoder: Non-autoregressive(…

网络基础——网络的发展史

作者简介&#xff1a;一名计算机萌新、前来进行学习VUE,让我们一起进步吧。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;我叫于豆豆吖的主页 目录 前言 一.网络发展史 1. ARPANET 2.TCP/IP协议 3. 互联网 4.Web浏览器 5.搜索引擎 6. 社交网…

如果你访问了某个网站,又不想让人知道怎么办?

问大家一个问题&#xff1a;如果你访问了某个网站&#xff0c;又不想让人知道怎么办&#xff1f; 你可能会说&#xff0c;把浏览器浏览历史记录清除&#xff0c;或者直接用无痕模式。 如果你只能想到这一层&#xff0c;那只能说图young&#xff01; 这么说吧&#xff0c;理论…

操作系统原理 —— 调度的概念、层次(十一)

调度的基本概念 在操作系统中的调度&#xff0c;是指操作系统从就序队列中选择一个作业&#xff0c;或者进程进行执行。 举个例子&#xff1a; 比如我们去银行窗口排队&#xff0c;排队的人就相当于就绪列表&#xff0c;窗口就相当于是操作系统&#xff0c;窗口需要服务排队…

npm的使用和命令

3.0 npm 什么是npm 是node管理包的工具 3.1 初始化包管理描述文件 package.json npm init // 会询问你每次的选项 或 npm init -y // 不询问你选项&#xff0c;默认就是确定 首先建立一个文件在路径里面全选写cmd 然后打开环境 在里面写npm init -y回车 就会在你原来空的文…

编写用户帮助/操作手册指南

背景&#xff1a; 用户操作手册是一份指导用户使用产品或服务的重要手册。 一个新系统&#xff0c;需要写用户操作手册&#xff0c;该从何下笔&#xff1f;本篇是一篇教你编写用户帮助/操作手册的指南&#xff5e; 首先&#xff0c;先来看一个反例 &#xff1a; 这个是我入职…

移动通信(17)预编码

源于某篇学位论文 利用预编码技术可以有效抑制大规模天线传输中的干扰&#xff0c;提高链路的峰值速率。大规模天线技术在提升性能的同时也存在很大的干扰问题。多天线传输中带来的多径干扰不可忽视。通常在接收端抑制干扰算法通常实现起来较为复杂&#xff0c;若采用预编码技…

安装Node.js和cnpm

一、安装Node.js 1.下载 Node.js官网下载 根据自身系统下载对应的安装包&#xff08;我这里为Windows10 64位&#xff0c;故选择下载第一个安装包&#xff09; 2、然后点击安装&#xff0c;选择自己要安装的路径&#xff0c;此处我选择的是&#xff1a;D:\Program Files\node…