import java.util.Arrays; public class Task { public static void main(String[] args) { System.out.println(concat('-', 1, 2, 3, 4, 5, 6, 7, 8, 9, 10)); System.out.println(concat('_', 123,345)); } public static String concat(char c, int... args) { // 用c作为分隔符,将args中的所有元素拼接成一个字符串 // 例如:c='-',args={1,2,3},返回"1-2-3" /* TODO */ } }
时间: 2023-05-21 09:01:08 浏览: 98
这是一个 Java 编程问题,需要实现一个静态方法 concat,该方法接收一个字符 c 和一个可变参数 args,将 args 中的所有元素用 c 连接成一个字符串并返回。具体实现可以使用 StringBuilder 类来拼接字符串。以下是可能的实现代码:
public static String concat(char c, int... args) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < args.length; i++) {
sb.append(args[i]);
if (i < args.length - 1) {
sb.append(c);
}
}
return sb.toString();
}
相关问题
package five; public class five { public static void main( String [] args ) { String s1 = " 1234567890QWERTYUIOPqwertyuiop~!@#~$%^^&~我们永远热爱和平 "; System.out.println("s1 = " + s1); int s1_len = s1.length(); System.out.println( s1_len ); String s2 = s1.substring( 10, 20 ); System.out.println( s2 ); char c = s1.charAt( 10 ); System.out.println( c ); String s3 = s1.concat("世界!"); System.out.println( s3 ); String s4 = s1; boolean b1 = s3 == s4; System.out.println( b1 ); int index = s1.indexOf('3'); System.out.println( index ); s1 = s1.trim(); s1.toUpperCase(); System.out.println( s1 ); char cc[] = s1.toCharArray(); System.out.println( java.util.Arrays.toString(cc) ); } }
这是一个Java类,名为five。它包含一个main方法,用于测试一些字符串操作。在main方法中,定义了一个字符串s1,然后对其进行了多种操作:
1. 使用length()方法获取字符串长度,并将其输出。
2. 使用substring()方法从s1中获取子字符串,然后将其输出。
3. 使用charAt()方法获取s1中指定位置的字符,并将其输出。
4. 使用concat()方法将字符串s1和"世界!"拼接起来,并将拼接后的结果输出。
5. 将s1赋值给s4,然后使用"=="运算符比较s3和s4是否相等,并将比较结果输出。
6. 使用indexOf()方法查找字符'3'在s1中第一次出现的位置,并将其输出。
7. 使用trim()方法去除s1首尾的空格,然后使用toUpperCase()方法将其转换为大写字母,并将结果输出。
8. 使用toCharArray()方法将s1转换为字符数组,然后使用Arrays.toString()方法将字符数组转换为字符串,并将其输出。
需要注意的是,虽然使用了trim()和toUpperCase()方法,但是s1本身并没有被修改,因为在Java中String是不可变的。
mysql 字符串转String[]
可以使用 MySQL 中的 `GROUP_CONCAT()` 函数来将字符串连接成一个逗号分隔的字符串,然后使用 Java 中的 `String.split()` 方法将其分割成一个字符串数组。
例如,假设有一个名为 `my_table` 的 MySQL 表,其中有一个名为 `my_column` 的字符串类型列,包含以下值:`'a,b,c'`、`'d,e'`、`'f'`。
以下是将这些字符串转换为字符串数组的示例 Java 代码:
```java
import java.sql.*;
import java.util.Arrays;
public class MySQLToStringArrayExample {
public static void main(String[] args) throws SQLException {
String url = "jdbc:mysql://localhost:3306/my_database";
String user = "my_username";
String password = "my_password";
Connection conn = DriverManager.getConnection(url, user, password);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT GROUP_CONCAT(my_column SEPARATOR ',') AS my_string FROM my_table");
if (rs.next()) {
String myString = rs.getString("my_string");
String[] myArray = myString.split(",");
System.out.println(Arrays.toString(myArray)); // Output: [a, b, c, d, e, f]
}
rs.close();
stmt.close();
conn.close();
}
}
```
在此示例中,我们使用 `GROUP_CONCAT()` 函数将 `my_column` 列中的所有值连接为一个逗号分隔的字符串,并将其作为名为 `my_string` 的结果集列返回。然后,我们使用 `getString()` 方法从结果集中提取该字符串,并使用 `split()` 方法将其分割成字符串数组。最后,我们在控制台上打印该数组。
阅读全文