题解 | #压缩牛群编号#

压缩牛群编号

https://www.nowcoder.com/practice/db9dd240e5f54b6d8eeadfbd9b7f865f

考察双指针算法的应用。具体代码细节如下所示,使用Java代码。

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param chars char字符型一维数组 
     * @return char字符型一维数组
     */
    public char[] compress (char[] chars) {
        // write code here
        int n = chars.length, write = 0;
        for(int i =0;i<n;){
            int j = i;
            while(j<n && chars[i] == chars[j]){
                ++j;
            }
            chars[write++] = chars[i];
            if(j - i >1){
                String tmp = Integer.toString(j-i);
                for(int k = 0;k<tmp.length();++k){
                    chars[write++] = tmp.charAt(k);
                }
            }
            i = j;
        }  
        char[] res = new char[write];
        for(int i=0; i<write; i++){
            res[i] = chars[i];
        }
        return res;
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 18:05
哈哈哈哈哈感觉朋友找工作的已经疯掉了,直接上图
码农索隆:真老板娘:“我嘞个去,这不我当年的套路吗
点赞 评论 收藏
分享
流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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