StringBuffer str = new (sc.nextLine());为什么出错
时间: 2024-03-08 16:50:52 浏览: 69
这段代码出错的原因是 `new` 关键字后面缺少了要创建的对象的类型,应该使用 `StringBuffer` 类型,即 `new StringBuffer(sc.nextLine())`。
修改后的代码如下:
```
Scanner sc = new Scanner(System.in);
StringBuffer str = new StringBuffer(sc.nextLine());
```
这样就可以通过 `Scanner` 对象读取用户输入的字符串,并将其存储到 `StringBuffer` 对象中。
相关问题
package 小组作业; import java.util.Scanner; public class day2 { private static StringBuffer modify(StringBuffer s) { StringBuffer str = new StringBuffer("We are happy."); for (int i = 0; i < str.length(); i++) { if (str.charAt(i) == ' ') { str.replace(i, i+1, "%20"); } } return s; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); StringBuffer str = new StringBuffer(sc.nextLine()); System.out.println(modify(str)); } }不出结果
这段代码没有正确调用 `modify()` 方法。在 `main()` 方法中,你应该传入读取到的字符串 `str`,而不是固定字符串 `We are happy.`。此外,在 `modify()` 方法中,你也没有使用传入的参数 `s`,而是使用了固定字符串 `We are happy.`,这也是不正确的。
修改 `modify()` 方法中的代码,使用传入的字符串 `s`:
```
private static StringBuffer modify(StringBuffer s) {
for (int i = 0; i < s.length(); i++) {
if (s.charAt(i) == ' ') {
s.replace(i, i+1, "%20");
}
}
return s;
}
```
修改 `main()` 方法中的代码,传入读取到的字符串 `str`:
```
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
StringBuffer str = new StringBuffer(sc.nextLine());
System.out.println(modify(str));
}
```
这样就可以正确读取用户输入的字符串,并将其中的空格替换成 `%20`。
class CommonOrder { static StringBuffer s1;// save string1 static StringBuffer s2;// save string2 static StringBuffer s3;// save commom string CommonOrder(String str1,String str2) { s1=new StringBuffer(str1); s2=new StringBuffer(str2); s3=new StringBuffer(); } /* 你编写的subsequenceOrder()函数的代码将被嵌在这里 */ StringBuffer getCommonString(){ return s3; } } public class Main{ public static void main(String[] args) { String X = null,Y = null; Scanner sc=new Scanner(System.in); if(sc.hasNext()) X=sc.nextLine(); if(sc.hasNext()) Y=sc.nextLine(); CommonOrder co=new CommonOrder(X,Y); co.subsequenceOrder(); StringBuffer str=co.getCommonString(); System.out.println(str+" "+str.length()); } }
以下是subsequenceOrder()函数的代码,它将找到s1和s2的最长公共子序列,并将其存储在s3中:
```
class CommonOrder {
static StringBuffer s1;// save string1
static StringBuffer s2;// save string2
static StringBuffer s3;// save commom string
CommonOrder(String str1, String str2) {
s1 = new StringBuffer(str1);
s2 = new StringBuffer(str2);
s3 = new StringBuffer();
}
void subsequenceOrder() {
int m = s1.length();
int n = s2.length();
int[][] dp = new int[m + 1][n + 1];
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
if (s1.charAt(i - 1) == s2.charAt(j - 1)) {
dp[i][j] = dp[i - 1][j - 1] + 1;
} else {
dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]);
}
}
}
int index = dp[m][n];
int i = m, j = n;
while (i > 0 && j > 0) {
if (s1.charAt(i - 1) == s2.charAt(j - 1)) {
s3.append(s1.charAt(i - 1));
i--;
j--;
index--;
} else if (dp[i - 1][j] > dp[i][j - 1]) {
i--;
} else {
j--;
}
}
s3.reverse();
}
StringBuffer getCommonString() {
return s3;
}
}
```
该算法使用动态规划来找到s1和s2的最长公共子序列。在找到最长公共子序列之后,它将反转s3,以便输出正确的顺序。
阅读全文