java比对文字重复_在 java 中重复一个字符串 n 次的几种方法

今天在 js 库中看到一个重复字符串的方法:

export function repeat (character, count) {

return Array(count + 1).join(character)

}

功能即是把 character 字符串重复 count 次,我想使用 java 该怎么实现,记得 java 里应该有 join 方法的。

java 中大概有 4 种方法可以实现这个需求。

方法一:format

即使用 String.format 的占位符替换方式。

int count = 5;

String character = "daimafans";

String repeated = String.format("%0" + count + "d", 0).replace("0", character);

System.out.println(repeated);

// 结果

// daimafansdaimafansdaimafansdaimafansdaimafans

方法二:replace

其实和第一种是一样的,都是生成 n 位的 0 字符串,然后使用 String.replace 方法去替换。

int count = 5;

String character = "daimafans";

String repeated = new String(new char[count]).replace("\0", character);

方法三:Collections.nCopies

先使用 Collections.nCopies 接口把字符串拷贝到 count 大小的列表中,然后使用 String.join 拼接到一起。

int count = 5;

String character = "daimafans";

String repeated = String.join("", Collections.nCopies(count, character));

方法四:StringBuffer.append

这个方法应该是最容易想到的,把同一字符串循环拼接多次,简单粗暴好用。

StringBuffer buffer = new StringBuffer();

for (int i = 0; i < count; i++) {

buffer.append(character);

}

String repeated = buffer.toString();

性能对比

每种方式循环执行 1000000 次,耗时的毫秒数:

方法

耗时(毫秒)

1797

593

167

142

根据前面的总结和测试,相对而言,3 和 4 的耗时比较少,多次测试的结果 4 都比 3 用时更少一点。

注重性能就选择 3 或 4。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Java的IO流读取两个文本文件的内容,然后使用字符串比对方法来找出相同和不同之处。 具体实现步骤如下: 1. 使用Java的IO流读取两个文本文件的内容,可以使用BufferedReader来读取文本文件。 2. 将读取到的文本内容转换为字符串,可以使用StringBuilder类来拼接字符串。 3. 使用字符串比对方法来找出相同和不同之处,可以使用JavaString类的equals()方法比对字符串是否相同,也可以使用字符串的indexOf()方法来找出字符或者字符串字符串的位置。 4. 将找出的相同和不同之处标记出来,可以使用Java字符串拼接或者替换的方法来标记相同和不同之处。 下面是一个比对两个文本文件并标记相同与不同之处的Java代码示例: ```java import java.io.BufferedReader; import java.io.FileReader; public class TextCompare { public static void main(String[] args) { String file1 = "file1.txt"; String file2 = "file2.txt"; try { // 读取文件1的内容 BufferedReader reader1 = new BufferedReader(new FileReader(file1)); StringBuilder sb1 = new StringBuilder(); String line1; while ((line1 = reader1.readLine()) != null) { sb1.append(line1); } reader1.close(); // 读取文件2的内容 BufferedReader reader2 = new BufferedReader(new FileReader(file2)); StringBuilder sb2 = new StringBuilder(); String line2; while ((line2 = reader2.readLine()) != null) { sb2.append(line2); } reader2.close(); // 比对字符串 String str1 = sb1.toString(); String str2 = sb2.toString(); if (str1.equals(str2)) { System.out.println("两个文本文件完全相同!"); } else { // 标记相同和不同之处 StringBuilder result = new StringBuilder(); int len1 = str1.length(); int len2 = str2.length(); int len = Math.min(len1, len2); for (int i = 0; i < len; i++) { if (str1.charAt(i) == str2.charAt(i)) { result.append(str1.charAt(i)); } else { result.append("["); result.append(str1.charAt(i)); result.append(":"); result.append(str2.charAt(i)); result.append("]"); } } if (len1 > len2) { result.append(str1.substring(len2)); } else if (len1 < len2) { result.append(str2.substring(len1)); } System.out.println("两个文本文件不完全相同!"); System.out.println("相同之处:" + result.toString()); } } catch (Exception e) { e.printStackTrace(); } } } ``` 注意:在比对字符串时,上面的代码只是简单地比对字符串每个字符是否相同,如果需要比对字符串的单词或者句子是否相同,需要先进行字符串分割处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值