首页 > 其他分享 >2.27 总结

2.27 总结

时间:2023-02-27 22:35:25浏览次数:60  
标签:总结 java String 单词 io import txt 2.27

大家经常玩成语接龙游戏,我们试一试英语的接龙吧:一个文本文件中有N 个不同的英语单词, 我们能否写一个程序,快速找出最长的能首尾相连的英语单词链,每个单词最多只能用一次。

最长的定义是:最多单词数量,和单词中字母的数量无关。

1、统一输入文件名称:input1.txt, input2.txt

2、统一输出文件名称:output1.txt,output2.txt

3、程序需要考虑下列异常状况:

(1)例如,文件不存在,你的程序会崩溃么,还是能优雅地退出并给用户提示信息?

(2)如果文件没有任何单词、只有一个单词、没有可以首尾相连的单词,程序应该如何输出?

(3)如果输入文件有一万个单词,你的程序能多快输出结果?

 

 

package word;
 
import java.awt.geom.Area;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.OutputStream;
 
public class dancilian {
    public static void main(String[] args) {
dancilian a=new  dancilian();
File file = new File("E:/input1.txt");
String b=a.read(file);
String[] A =b.split(" ");
String[] f;
String[] l;
String[] end;
f=a.first(A);
l=a.last(A);
end=a.jielong(A, l, f);
 
for(int i=0;i<3;i++)
System.out.println(end[i]);
try {
    a.write(end);
} catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}
    }
 
    public String[] first(String[] A)//返回首字母数组
    {
        String[] F= new String[A.length];
        for(int i=0;i<A.length;i++)
        {
            F[i]=A[i].substring(0,1);
            }
        return F;
    }
     
    public String[] last(String[] A)//返回尾字母数组
    {
        String[] L= new String[A.length];
        for(int i=0;i<A.length;i++)
        {
            L[i]=A[i].substring(A[i].length()-1);
            }
        return L;
    }
 
public String[] jielong(String[] A,String[] L,String[] F)//获取接龙字母
{
    String[] end=new String[A.length];
    int  k=0;
         end[0]=A[0];
         for(int j=0;j<A.length;j++)
         {
         if((end[k].substring(end[k].length()-1)).equals(F[j]))
         {
             //System.out.println(end[k].substring(end[k].length()-1));
                 end[++k]=A[j];
         }
         }     
    return end;
}
 
 
public String read(File file){//读出文件
    StringBuilder result = new StringBuilder();
    try{
        BufferedReader br = new BufferedReader(new FileReader(file));//构造一个BufferedReader类来读取文件
        String s = null;
        while((s = br.readLine())!=null){//使用readLine方法,一次读一行
            result.append(System.lineSeparator()+s);
        }
        br.close();   
    }catch(Exception e){
        e.printStackTrace();
    }
    return result.toString();
}
public void write(String[] str) throws Exception{//写入文件
    //在d盘上创建一个名为testfile的文本文件
    File f = new File("E:/output1.txt");
    //用FileOutputSteam包装文件,并设置文件可追加
    OutputStream out = new FileOutputStream(f,true);
    //字符数组
    //String[] str = {"shanghai","beijing","guangdong","xiamen"};
    for(int i=0; i<str.length; i++){
    out.write(str[i].getBytes()); //向文件中写入数据
    out.write('\r'); // \r\n表示换行
    out.write('\n');
    }
    out.close(); //关闭输出流
    System.out.println("写入成功!");
    }
}

 

标签:总结,java,String,单词,io,import,txt,2.27
From: https://www.cnblogs.com/kk4458/p/17162224.html

相关文章

  • 今日总结
    代码时间(包括视频学习时间):4.5h代码量(行):450行博客数量(篇):4篇了解到的知识点:1、学会了设置德鲁伊数据可连接池2、学会了链接数据库和查询所有3、病也终于块好了......
  • JVM总结
    1.内存结构线程私有区程序计算器作用:是一块较小的内存空间,存储的是当前线程所执行的字节码文件的序号特点:线程私有,不会出现内存空间溢出虚拟机栈虚拟机栈是管理J......
  • 2023.2.27每日总结
    getCount()获得viewpager中有多少个viewinstantiateltem()1.将给定位置的view添加到viewGroup(容器)中,创建并显示出来2.返回一个代表新增页面的Object(key)通常都是直接返......
  • 每日总结(7)
    所用时间:一下午代码:83博客:3知识点:Android的案例计算器课堂练习,寻找首尾相接链1packagecom.text;23importorg.omg.CORBA.WStringSeqHelper;45i......
  • 2023/2/27号周一总结
     今天上午没课,在宿舍呆了一上午,写作业和练习编代码。下午是建民老师的课,老师讲了一些关于软件工程的知识和让我们做了一个将文章里单词首尾字母相连最长的单词链这样一个......
  • 今日课上测试题总结-计算最长英语单词链
    今天软工课上老师留的作业总结一下1importjava.io.*;2importjava.util.*;34publicclassMaxlist{56publicstaticvoidmain(String[]args)th......
  • 2月27日每日总结
    今天下午是一周一度的Java课,在课上,老师让我们做了一个小练习,但我还没有完全弄出来,下灭是我暂时的成果:packageaaa;importjava.util.ArrayList;importjava.util.HashSet;......
  • 2023年2月27日学习总结
    今天上午继续学习了androidapp的开发,知道了如何创建数据库,创建表,和页面间数据的传递。下午上课时按照老师的要求要做一个对文本文件中英文单词的接龙,找出最长的单词链,刚......
  • 学习记录(2.27)
    学习时长:6h代码行数:约160行今天继续进行了小游戏flappychicken的开发,成功debug了两次,解决了鸡无法触发管道侧边碰撞的问题,并且对地图进行了一些优化。......
  • 2023.2.27
    课堂练习01题目:计算最长英语单词链。一、题目内容:大家经常玩成语接龙游戏,我们试一试英语的接龙吧:一个文本文件中有N 个不同的英语单词,我们能否写一个程序,快速找出最长......