已知数组存放一批QQ号码,QQ号码最长为11位,最短为5位: String[] strs = {"12345","67891","12347809931","98765432102","67891","12347809932","12347809934"}; 将该数组里面的所有QQ号都存放在LinkedList中,然后遍历链表,查找list中指定长度的QQ号,并统计数量,并输出;如果不存在指定长度的QQ号,则输出“-1”。
Main类:在main方法中,调用constructList方法将strs中的字符串存入一个String的链表中,然后调用search方法统计指定长度的QQ号的数量,并打印到屏幕。
编写StringList类,编程要求如下:
- 根据程序需求,定义成员变量、编写构造方法。
- LinkedList constructList(String[] strs) 方法:将String数组strs中的元素添加到链表中,构建一个String对象链表,最后返回链表。
- String search(LinkedList list)方法:使用scanner的nextInt()方法从键盘读入一个int,表示指定长度;然后遍历链表,查找出链表中个指定长度的QQ号码,并统计指定长度的QQ号的数量;如果不存在指定长度的QQ号,则返回"-1"。
函数接口定义:
在这里描述函数接口。例如:
int Count_Digit ( const int N, const int D );
在这里解释接口参数。例如:其中 N
和 D
都是用户传入的参数。 N
的值不超过int
的范围; D
是[0, 9]区间内的个位数。函数须返回 N
中 D
出现的次数。
裁判测试程序样例:
import java.util.LinkedList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
String[] strs = {"12345","67891","12347809931","98765432102","67891","12347809932","12347809934"};
StringList sl=new StringList();
LinkedList<String> qqList=sl.constructList(strs);
System.out.println(sl.search(qqList));
}
}
/* 请在这里填写答案:StringList类 */
输入样例:
在这里给出一组输入。例如:
5
输出样例:
在这里给出相应的输出。例如:
3
代码实现:
class StringList{
LinkedList<String> constructList(String[] strs) {
LinkedList<String> li=new LinkedList<>();
for(int i=0;i<strs.length;i++){
li.add(strs[i]);
}
return li;
}
String search(LinkedList<String> list) {
Scanner s=new Scanner(System.in);
int n=s.nextInt();
int count=0;
for (String value : list) {
if (value.length() == n) {
count++;
}
}
if(count!=0) {
return String.valueOf(count);
}else return "-1";
}
}