将char数组中的字符依次替换str中的‘占位符‘算法-java

package com.huahui.service_test01.pojo.query;

/**
 * @author lisq
 * date 2023/4/4 19:26
 * version 1.0
 * @description TODO
 */
public class tests {

    /**
     * 测试数据
     *
     * @param args
     */
    public static void main(String[] args) {
        String str = "A%sB%sC%sG%sH%sGFG";
        char[] arg = new char[]{'D', 'E', 'F', 'J', 'V', 'Z'};
        System.out.println("得到的答案为:" + formatString(str, arg, "%s"));
    }

    /**
     * 将char数组中的字符依次替换str中的'占位符',当数组中字符多于 str中的'占位符'的数量,则多出的字符拼接在Str字符串后面
     *
     * @param str   字符串
     * @param arg   代替'占位符'的字符
     * @param regex 占位符
     * @return 替代后的字符串
     */
    public static String formatString(String str, char[] arg, String regex) {
        int i;
        StringBuffer buffer = new StringBuffer("");
        //根据占位符分割str字符
        String[] split = str.split(regex);
        //split.length - 1 表示'占位符的'个数
        if (split.length - 1 >= arg.length) {
            for (i = 0; i < split.length; i++) {
                if (i < arg.length) {
                    buffer.append(split[i]).append(arg[i]);
                }
                //拼接多出来的原有的str的字符
                else {
                    //判断是否是最后一个字符串
                    if (i == split.length - 1) {
                        //判断最后一个字符是否是分割符,是拼接分割符,不是则不拼接
                        if (str.lastIndexOf(regex) == str.length() - regex.length()) {
                            buffer.append(split[i]).append(regex);
                        } else {
                            buffer.append(split[i]);
                        }
                    } else {
                        buffer.append(split[i]).append(regex);
                    }
                }
            }
        } else {
            for (i = 0; i < arg.length; i++) {
                if (i < split.length) {
                    buffer.append(split[i]).append(arg[i]);
                } else {
                    buffer.append(arg[i]);
                }
            }
        }
        return buffer.toString();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值