随机打乱数组及字符串后追加指定个数字符的方法

       实际做业务开发时,需求是千变万化的,一个大功能点会包含很多小功能点,小功能点又会包含若干环节,具体到每个环节,代码实现上又是五花八门,这取决于程序员的编程思路和工作态度,我想不应该仅仅满足功能实现,还应该尽可能的找到最佳实践。对于最佳实践,每个人都有不同理解和定义,简洁、高效、易懂,这是我的理解。刚好最近工作中用到随机打乱数组方法和字符串追加字符方法,实现起来非常简单。对于随机打乱数组的方法,查资料时,发现大家也叫它洗牌算法,也对,一组数据,随机打乱,和洗牌差不多。最先想到的是以前写cnn卷积神经网络代码时,读取样本后,每轮迭代训练时,都需要随机打乱样本,c代码如下(如果对深度学习感兴趣,正在发愁找不到入门示例,可以看看我写的这份LeNet-5代码,谁用谁知道,已开源):

for (i = 0; i < train_sample->sample_count; i++)
{
    rand_perm[i] = i;
}

for (i = 0; i < train_sample->sample_count; i++)
{
    j = genrand_int31() % (train_sample->sample_count - i) + i;
    t = rand_perm[j];
    rand_perm[j] = rand_perm[i];
    rand_perm[i] = t;
}

       然后我又查了一下,很多博客提及的洗牌算法,java代码如下:

for (int i = n-1; i >= 0; i--) {
    index = rand(i + 1)%i + 1
    if(i != index) {
        exchange(i, index)
    }        
}

       其实,上面两种方法大同小异,核心思想都对于有序数组,遍历时就是不断将当前元素和后面随机位置的元素交换,进而打乱整个数组。不过进一步查资料发现了更简单的方法,可以使用Collections.shuffle(list),也就是直接使用库函数实现,不是自己手写的不好,而是这些库更健壮、更高效,用起来很方便,也就没必要重复造轮子了。

       同样,对于字符串追加字符的方法,如果使用java,我们肯定想到定义一个StringBuilder,用一个for循环,循环次数也就是追加字符的个数,然后不断的append()就好了,最后输出结果。这样实现没问题,但至少也得写个一小段代码来实现,更简洁、省事的方法是直接使用apache开源commons-lang3库中的StringUtils.repeat()方法,或者StringUtils.rightPad() / StringUtils.leftPad()方法,这样一行代码就搞定了,这个库有很多实用的字符串处理方法。并不是说这些库有多好,这个需要结合工作实际来看待,手写这些功能点的能力还是要有的,不能凡事都去找这些库,如果因为一个小功能点自己懒得写,而引入一个庞然大物一样的库,结果这个库95%的功能都用不到,仅仅用了一丢丢的功能,那就感觉有点得不偿失了。当然引入库,也得看哪里出品的,活跃度如何,也得是高质量的库才行,否则bug一堆,还是算了吧,不如自己手写来的实在。

public  String repeat(char ch, int repeat) {
    if (repeat <= 0) {
        return "";
    } else {
        char[] buf = new char[repeat];
        for(int i = repeat - 1; i >= 0; --i) {
            buf[i] = ch;
        }

        return new String(buf);
    }
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值