题解 | #替换空格#

替换空格

https://www.nowcoder.com/practice/0e26e5551f2b489b9f58bc83aa4b6c68

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param s string字符串
     * @return string字符串
     */
    public String replaceSpace (String s) {
        // write code here
        char[] ochars = s.toCharArray();
        // 1 统计空格数量
        int spaceNum = 0;
        for (int i = 0; i < ochars.length; i++) {
            if (ochars[i] == ' ') {
                spaceNum++;
            }
        }

        // 2 初始化新数组
        int nCharsLength = ochars.length + 2 * spaceNum;
        char[] nChars = new char[nCharsLength];

        // 3 根据旧数组填充新数组
        int nCharsIndex = 0;
        for (int index = 0; index < ochars.length; index++) {
            if (ochars[index] != ' ') nChars[nCharsIndex++] = ochars[index];
            else {
                // 遇到空填充三个值
                nChars[nCharsIndex++] = '%';
                nChars[nCharsIndex++] = '2';
                nChars[nCharsIndex++] = '0';
            }
        }
        return new String(nChars);
    }
}

解题思想:计算空值数量+新数组初始化+遍历旧值填充数据和空值

#算法笔记##算法#
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 18:19
个个985的硕士闭着眼睛都有15k以上的月薪,天天嚷嚷着研究生白度读了,天天嚷嚷着反向读研了........
MMMJC:不读研22本科出去的基本都拿28k呢,你不能用25的研究生和25的本科生比然后说没反向读研,而是25研和22本比呀
点赞 评论 收藏
分享
头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务