java:最长字符串
题目
求出5个字符串中最长的字符串。每个字符串长度在100以内,且全为小写字母。
样例输入
one two three four five
样例输出
three
知识点
使用StringTokenizer对象分解String对象的字符序列
和split()方法不同的是,StringTokenizer对象不使用正则表达式作为分隔标记
有时需要分析String对象的字符序列并将字符序列分解成可被独立使用的单词,这些单词叫做语言符号。
当分析一个String对象的字符序列并将字符序列分解成可被独立使用的单词时,可以使用java.util包中的StringTokenizer类,该类有两个常用的构造方法
StringTokenizer(String s):为String对象s构造一个分析器。使用默认的分割标记,即空格符,换行符,回车符,Tab符,进纸符做分割标记
StringTokenizer(String s,String delim):为String对象s构造一个分析器。参数delim的字符序列中的字符的任意排列被作为分隔标记
hasMoreTekens()
计数,大于0就返回true,否则返回false
nextToken()
这个算法作废:因为这个不能保存,我也不知道怎么保存分隔了的数,之后我就进行不了比较大小!!
import java.util.Scanner;
import java.util.StringTokenizer;
public class 最长字符串 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
StringTokenizer s=new StringTokenizer(sc.next());//StringTokenizer类
while(s.hasMoreTokens()){//计数
for(int i=0;i<1000;i++){
=s.nextToken();//进行赋值
}
}
}
}
换方法
next():简单来说,就是遇到空格就结束了,后面的内容不管它。
nextline():简单来说,就是把整一行全部的内容接受到了。(很好理解的,这里后面有个line嘛)
我的理解都写在代码后面了
import java.util.Scanner;
public class 最长字符串 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
String [] a=new String [5];//题目说的是五个字符串
for(int i=0;i<5;i++){
a[i]=sc.next();//遇到空格就停了
}
//找出每个的长度
int maxL=0;//选确定比较的值,这个就和排序算法差不多
String s="";//定义一个字符串,转载最长的单词
for(int i=0;i<5;i++){
if(a[i].length()>maxL){//如果大于最大的长度
maxL=a[i].length();//长度赋予maxL
s=a[i];//进行赋值
}
}
System.out.println(s);
}
}
如果用nextline()就是要进行分隔
import java.util.Scanner;
public class 最长字符串1 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
String word=sc.nextLine();//用nextLine来存储
String [] a=word.split(" ");//按空格进行分割,分割了之后存放在数组里面
//找出每个的长度
int maxL=0;//选确定比较的值,这个就和排序算法差不多
String s="";//定义一个字符串,转载最长的单词
for(int i=0;i<5;i++){
if(a[i].length()>maxL){//如果大于最大的长度
maxL=a[i].length();//长度赋予maxL
s=a[i];//进行赋值
}
}
System.out.println(s);
}
}
这个nextLine启发了我我就重新改了一下第一个的代码,在eclipse里面运行没有问题,但不知道为什么在程序里面运行不了,编译没错误,就是不对,我电脑打开直接是txt,不能知道是不是空格问题
import java.util.Scanner;
import java.util.StringTokenizer;
public class 最长字符串2 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
StringTokenizer s=new StringTokenizer(sc.next());//StringTokenizer类
String [] a=new String [5];
for(int i=0;i<5;i++){
a[i]=s.nextToken();//nextToken返回值是String
}
int maxL=0;
String m="";
for(int i=0;i<5;i++){
if(a[i].length()>maxL){//如果大于最大的长度
maxL=a[i].length();//长度赋予maxL
m=a[i];//进行赋值
}
}
System.out.println(m);
}
}