【Java习作】KWIC模拟

简介: 作者:gnuhpc 出处:http://www.cnblogs.com/gnuhpc/ package org.bupt.kwic; import java.io.BufferedReader; import java.

作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/

package org.bupt.kwic;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.StringTokenizer;
public class mykwic {
    private static BufferedReader input_file;
    private ArrayList<String> kwicList;
    public mykwic (String filename)   //construct the index of file fname
    {
        kwicList = new ArrayList<String>();
        String line="";
        fileopen(filename);
        while (line!= null)
        {
            line= readline();
            if (line !=null)
            {
                parseLine(line, kwicList);
            }
          }
         //Collections.sort(kwicList);
         display ( kwicList );
    }
    public static void fileopen(String InputFilename) {
        try {
            input_file = new BufferedReader(new FileReader(InputFilename));
        } catch (IOException e) {
            System.err.println(("File not open" + e.toString()));
            System.exit(1);
        }
    }
    public static String readline() {
        String line ="";
        try {
            line = input_file.readLine();
        } catch (Exception e) {
            e.getStackTrace();
        }
        return line;
    }
    public void parseLine(String line,ArrayList<String> list) {
        StringTokenizer tokener = new StringTokenizer(line);
        String token = new String();
        int index;
        ArrayList<String> tokens = new ArrayList<String>();
        int count = tokener.countTokens();
        for (int j = 0; j < count; j++) {//将一行解析,并且将解析的word加入ArrayList中
            token = tokener.nextToken();
            tokens.add(token);
        }
        //对ArrayList中的字进行循环移位,得出最后结果
        for (int i = 0; i < count; i++) {
            index=i;
            StringBuffer linebuffer = new StringBuffer();
            for (int j = 0; j < count; j++) {
                if (index >= count)
                      index = 0;
                    linebuffer.append ( tokens.get(index)  );
                    linebuffer.append (" ");
                    index++;
            }
            line = linebuffer.toString();
            kwicList.add(line);
        }
    }
    public static void  display(ArrayList<String> List) {
        System.out.println("Output is");
        for (int count = 0; count < List.size(); count++) {
              System.out.println (List.get (count) );
        }
    }
    public static void main(String[] args) {
            new mykwic("test.txt");
    }
}

 

作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/


               作者:gnuhpc
               出处:http://www.cnblogs.com/gnuhpc/
               除非另有声明,本网站采用知识共享“署名 2.5 中国大陆”许可协议授权。


分享到:

目录
相关文章
|
网络协议 NoSQL Java
模拟面试一(Java)
模拟面试一(Java)
159 1
模拟面试一(Java)
|
存储 Java 索引
不可上位!数据结构队列,老实排队,Java实现数组模拟队列及可复用环形队列
不可上位!数据结构队列,老实排队,Java实现数组模拟队列及可复用环形队列
147 0
不可上位!数据结构队列,老实排队,Java实现数组模拟队列及可复用环形队列
|
存储 设计模式 Java
【Java作业】模拟停车场(超详细!)
【Java作业】模拟停车场(超详细!)
【Java作业】模拟停车场(超详细!)
|
存储 Java 程序员
Java 模拟二级文件系统 中
本系列将记述使用 Java 实现一个简单的二级文件系统的过程。本项目意图效仿 Linux 的文件管理,但是学的又没那么像,仅仅是一些皮毛。因此使用类似 Inode 的东西记录文件在磁盘上的信息。
229 1
|
存储 Java 人机交互
Java 模拟二级文件系统 上
本系列将记述使用 Java 实现一个简单的二级文件系统的过程。
161 1
|
Java Scala 开发者
Java 模拟 Scala 的运行机制|学习笔记
快速学习 Java 模拟 Scala 的运行机制。
105 0
Java 模拟 Scala 的运行机制|学习笔记
|
存储 算法 Java
Java数据结构:使用数组模拟队列(队列与环形队列)
文章目录 1 队列 1.1 何为队列及实现思路 1.2 数组模拟队列ArrayQueue的实现 1.3 测试队列ArrayQueueDemo测试类的实现 2 环形队列 2.1 环形队列简介及实现思路 2.2 数组模拟环形队列CircleArrayQueue的实现 2.3 测试队列CircleArrayQueueDemo测试类的实现 写在最后
Java数据结构:使用数组模拟队列(队列与环形队列)
LinkedList的模拟实现(Java实现)
LinkedList的底层是用一个双向链表实现的,即一个结点中除了有一个引用指向下一个结点的地址,还有一个引用指向前一个结点的地址。
LinkedList的模拟实现(Java实现)
|
Java
Java模拟斗地主代码实现
Java模拟斗地主代码实现
116 0
Java模拟斗地主代码实现
|
存储 编解码 安全
CSDN实训 - Java模拟二次验证码(动态令牌)
CSDN实训 - Java模拟二次验证码(动态令牌)
CSDN实训 - Java模拟二次验证码(动态令牌)