力扣刷题篇之《空白替换》

这篇具有很好参考价值的文章主要介绍了力扣刷题篇之《空白替换》。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

❤️ 铁汁们大家好,欢迎大家来到出小月的博客里,今天小月呢写了一道题目叫替换空格,但是呢,写完之后调试了半天不知道哪里错了,经过小月的坚持不懈,终于成功,来分享给大家小月的错误,希望大家看完我这篇文章都能够“涨芝士”,感觉小月写的还不错的话,记得👍🏻点赞加关注😘鼓励一下博主哦,不然下次可找不到我啦❗❗


作者简介

❤️ 作者的主页:出小月的《程序员历险记》
❤️专栏:《C语言》,《数据结构初阶》
😊希望大家都能够:好好学习,天天编程❗❗❗



一、题目介绍

🐻

请实现一个函数,把字符串 s 中的每个空格替换成"%20"。
示例 1:
输入:s = “We are happy.”
输出:“We%20are%20happy.”

二、题目链接

替换空格力扣链接

三、小月的思路

首先,查这个字符串有多少个字符,并且有多少个空格字符,用来算出需要开辟的空间多大,然后开辟一个新的数组用来放替换空格之后的字符串,之后从后往前遍历就可以了。

四、小月出现的错误

小月呢,比较大意在数数组的时候就犯了两个大错误,导致花费了大量的时间,下面是小月之前写的错误的代码

 int count = 0;
    int spacecount = 0;
    while (*s != '\0')
    {
        s++;
        count++;
        if (*s == ' ')
            spacecount++;
    }

错误1

如果s这个指针指向的字符串只有一个空格呢?比如这样“ ”,进入while循环中,s++指向‘\0’,count=1,然后此时*s是‘\0’,这个空格就没有统计上。就导致后面新开辟的数组长度不够,就错了。需要把判断是否为空放到前面

错误2

力扣刷题篇之《空白替换》
力扣刷题篇之《空白替换》
看这两张图片p不断++,p[0]就不断改变,到下面p[oldi]或者p[newi]就越界访问了,因此需要一个指针指向它,改变指针,而不改变本事

五、正确代码

char* replaceSpace(char* s) {
    int count = 0;
    int spacecount = 0;
    char*p=s;
    while (*p != '\0')
    {
        if (*p == ' ')
            spacecount++;
        p++;
        count++;
    }
    int newlength = count + spacecount * 2;
   char* ret = (char*)malloc(sizeof(char) * (newlength + 1));
   //注意要多开辟一个空间因为字符串的结束标志为‘\0’,最后一位放‘\0’.
    for (int newi = newlength - 1, oldi = count - 1; oldi >= 0; newi--, oldi--)
    {
        if (s[oldi] == ' ')
        {
            ret[newi--] = '0';
            ret[newi--] = '2';
            ret[newi] = '%';
        }
        else
        {
            ret[newi] = s[oldi];
        }
    }
    ret[newlength] = '\0';
    return ret;
}

总结

当遇到问题的时候,我们需要多调试调试代码,放到VS上调试一下就知道错误在哪里了,也需要多画图。文章来源地址https://www.toymoban.com/news/detail-425798.html

到了这里,关于力扣刷题篇之《空白替换》的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【力扣刷题 | 第十六题】

    目录 前言: 198. 打家劫舍 - 力扣(LeetCode) 213. 打家劫舍 II - 力扣(LeetCode)  总结: 我们今天继续刷动态规划的题,希望大家可以和我一起坚持下去。 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有

    2024年02月15日
    浏览(44)
  • 力扣刷题笔记

    诸神缄默不语-个人CSDN博文目录 我以前刷过一波力扣,然后全忘了……从0开始的力扣复活赛! 以前刷题用的是Java,现在Java几乎忘光了,所以现在是Python 3 + Java双语选手。 以下题目按照力扣官方顺序排列。 449. 序列化和反序列化二叉搜索树 1281. 整数的各位积和之差 1749. 任意

    2024年02月14日
    浏览(39)
  • 力扣刷题:删除重复元素

    当处理排序数组时,删除重复元素是一个常见的问题。首先,我们来看一下如何解决这个问题,然后再进一步讨论如何处理允许最多重复两次的情况。 问题描述:给定一个已排序的数组,删除重复的元素,使得每个元素只出现一次,并返回新的长度。 使用双指针方法。一个

    2024年02月13日
    浏览(50)
  • 力扣刷题【第一期】

    1.爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 2.求两数的和(283) 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下

    2024年02月07日
    浏览(44)
  • 数据结构:力扣刷题

      给你一个  升序排列  的数组  nums  ,请你  原地  删除重复出现的元素,使每个元素  只出现一次  ,返回删除后数组的新长度。元素的  相对顺序  应该保持  一致  。然后返回  nums  中唯一元素的个数。 考虑  nums  的唯一元素的数量为  k  ,你需要做以下事情确

    2024年02月13日
    浏览(43)
  • 【力扣刷题 | 第十五天】

    目录 前言:  ​​​​​​​63. 不同路径 II - 力扣(LeetCode) 343. 整数拆分 - 力扣(LeetCode) 总结:         本篇我们主要刷动态规划的题,解题还是严格按照我们在【夜深人静写算法】栏目下的解题步骤,大家如果没学过动态规划的可以先看看我写的动态规划文章介绍。

    2024年02月15日
    浏览(42)
  • 【力扣刷题 | 第十三天】

    今天随机进行练习,题型上不会有什么限制,主要还是练习STL算法。 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。 注意:最终,合并

    2024年02月10日
    浏览(52)
  • 力扣刷题之优先队列

    前言:优先队列底层是由大根堆或小根堆数据结构实现的。 347. 前 K 个高频元素 给你一个整数数组  nums  和一个整数  k  ,请你返回其中出现频率前  k  高的元素。你可以按  任意顺序  返回答案。 示例 1: 示例 2: 题目解读:题目的要求是要我们找出在一个数组中找出k个

    2024年02月05日
    浏览(47)
  • 两个数组的交集(力扣刷题)

            给定两个数组  nums1  和  nums2  ,返回  它们的交集  。输出结果中的每个元素一定是  唯一  的。我们可以  不考虑输出结果的顺序  。 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/intersection-of-two-arrays   说明:  输出结果中的每个元素一定是唯一的。

    2023年04月09日
    浏览(43)
  • 【力扣刷题】整数拆分(动态规划)

    个人简历: 全栈领域新星博主, 万粉博主、 帮助初学者入门,记录自己的学习过程 个人主页:天寒雨落的博客_CSDN博客-C,CSDN竞赛,python领域博主 热门专栏:初学者入门C语言_天寒雨落的博客-CSDN博客   目录 动态规划 整数拆分 题目 思路 代码 执行结果 其基本思想是将待求解

    2024年02月03日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包