本文主要是介绍随机打乱数组及字符串后追加指定个数字符的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
实际做业务开发时,需求是千变万化的,一个大功能点会包含很多小功能点,小功能点又会包含若干环节,具体到每个环节,代码实现上又是五花八门,这取决于程序员的编程思路和工作态度,我想不应该仅仅满足功能实现,还应该尽可能的找到最佳实践。对于最佳实践,每个人都有不同理解和定义,简洁、高效、易懂,这是我的理解。刚好最近工作中用到随机打乱数组方法和字符串追加字符方法,实现起来非常简单。对于随机打乱数组的方法,查资料时,发现大家也叫它洗牌算法,也对,一组数据,随机打乱,和洗牌差不多。最先想到的是以前写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 + 1if(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);}
}
这篇关于随机打乱数组及字符串后追加指定个数字符的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!