亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? search.java

?? 對一個文件夾下面的doc和txt文件(文件夾下不包含文件夾)中的內容建立索引并實現了搜索功能。(代碼有缺陷
?? JAVA
字號:
package src;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.*;

import org.tartarus.snowball.SnowballStemmer;
import org.tartarus.snowball.ext.englishStemmer;
public class Search {
	
	/**
	 * @param args
	 */
	public Search() {
		new Index();
	}
	public String search(String inString){
		Stack<StringTokenizer> data = new Stack<StringTokenizer>();
		Stack<String> operator = new Stack<String>();
		operator.push("#");
		String output = "";
		int countparentheses = 0;//in order to check the formula
		StringTokenizer test = new StringTokenizer(inString," ()#",true);//in order to check the formula
		/*
		 * exception handler for wrong formula.some of exception handlers are enbeded in the mian method program
		 */
		while(test.hasMoreTokens()){
			String o = test.nextToken();
			if(o.equals("("))
					countparentheses ++;
			else if (o.equals(")"))
				countparentheses --;
		}	
		if (countparentheses != 0){
			return ("The formula is not correct,please check your input \"" + inString + "\"");
		}
		//alter and compute
		StringTokenizer tokens = new StringTokenizer(inString + "#"," ()#",true);
		if (tokens.countTokens() == 1){
			atomicQuery(tokens.nextToken());
		}
		else {
			while(tokens.hasMoreTokens()){
				String temp = tokens.nextToken();
				/*
				 * deal with the operant
				 */
				if(!temp.equals("AND") && !temp.equals("OR") && !temp.equals("NOT") && !temp.equals("(") && !temp.equals(")") && !temp.equals("#") && !temp.equals(" ")){
					data.push(atomicQuery(temp));
					output += temp + " ";
				}
				/*
				 * deal with the bracket
				 */
				else if(temp.equals( ")")){
					for(String o =operator.pop();!operator.isEmpty() && !o.equals("(");o = operator.pop()){
						if (o.equals("AND")){
							StringTokenizer behind = data.pop();
							StringTokenizer ahead = data.pop();
							data.push(and(ahead,behind));
						}
						else if (o.equals("OR")){
							StringTokenizer behind = data.pop();
							StringTokenizer ahead = data.pop();
							data.push(or(ahead,behind));
						}
						else if (o.equals("NOT")){
							StringTokenizer behind = data.pop();
							data.push(not(behind));
						}
						output += o + " ";
						o = operator.pop();
					}
				}
				else if(temp.equals("(")){
					operator.push(temp);
				}
				/*
				 *deal with the operator
				 */
				else{
					if(!operator.isEmpty()){
						String o = operator.pop();
						while(true){
							if (operator.isEmpty() || icp(temp)  >  isp(o)){
								operator.push(o);
								break;
								}
							if (o.equals("AND")){
								StringTokenizer behind = data.pop();
								StringTokenizer ahead = data.pop();
								data.push(and(ahead,behind));
							}
							else if (o.equals("OR")){
								StringTokenizer behind = data.pop();
								StringTokenizer ahead = data.pop();
								data.push(or(ahead,behind));
							}
							else if (o.equals("NOT")){
								StringTokenizer behind = data.pop();
								data.push(not(behind));
							}
							output += o + " ";
							o = operator.pop();
						}
					}
					operator.push(temp);
				}
			}
		}
		String result = "";
		StringTokenizer endTokens = data.pop();
		while (endTokens.hasMoreTokens()){
			result += endTokens.nextToken();
		}
		return result;
//		return "The correct answer of " + inString + " is\n" + output + "= " + data.pop() ;
}
	/*
	 * in stack priority
	 */
	private int isp(String sign){
		if(sign.equals("AND") || sign.equals("OR") || sign.equals("NOT"))
			return 3;
		else if(sign.equals("("))
			return 1;
		else if(sign.equals(")"))
			return 4;
		else 
			return 0;
	}
	/*
	 * in coming priority
	 */
	private int icp(String sign){
		if (sign.equals("AND") || sign.equals("OR") || sign.equals("NOT"))
			return 2;
		else if (sign.equals("("))
			return 4;
		else if (sign.equals(")"))
			return 1;
		else 
			return 0;
	} 
	private StringTokenizer and(StringTokenizer ahead,StringTokenizer behind){
		String result = "";
		TreeSet<String> former = new TreeSet<String>();
		while (ahead.hasMoreTokens()){
			former.add(ahead.nextToken());
		}
		while (behind.hasMoreTokens()){
			String token = behind.nextToken();
			if (former.contains(token)){
				result += token + "|";
			}
		}
		return new StringTokenizer(result,"|");	
	}
	private StringTokenizer or(StringTokenizer ahead,StringTokenizer behind){
		String result = "";
		TreeSet<String> former = new TreeSet<String>();
		while (ahead.hasMoreTokens()){
			String token = behind.nextToken();
			former.add(token);
			result += token + "|";
		}
		while (behind.hasMoreTokens()){
			String token = behind.nextToken();
			if (!former.contains(token)){
				result += token + "|";
			}
		}
		return new StringTokenizer(result,"|");	
	}
	private StringTokenizer not(StringTokenizer behind){
		String result = "";
		File directory = new File("test-files");
		File[] files = directory.listFiles();
		TreeSet<String> latter = new TreeSet<String>();
		while (behind.hasMoreTokens()){
			latter.add(behind.nextToken());
		}
		for (int i = 0;i < files.length;i ++){
			String fileName = files[i].getPath().substring(files[i].getPath().indexOf("\\") + 1);
			if (!latter.contains(fileName)){
				result += fileName + "|";
			}
		}
		return new StringTokenizer(result,"|");
	}
	private StringTokenizer atomicQuery(String keyword){
		StringTokenizer line = null;
		try{
			BufferedReader br = new BufferedReader(new FileReader("index"));
			line = new StringTokenizer(br.readLine(),":|");
			SnowballStemmer stemmer = new englishStemmer();
			stemmer.setCurrent(keyword.toLowerCase());
			stemmer.stem();
			if (stemmer.getCurrent().equalsIgnoreCase(line.nextToken()));
		}catch(IOException e){
			System.out.println(e);
		}
		return line;
	}
	public static void main(String args[]){
		Search s = new Search();
		System.out.println(s.search("exception"));
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月天一区二区三区| 成人动漫av在线| 国产精品一级二级三级| 91在线观看下载| 精品国产一区二区在线观看| 一区二区三区日本| 国产激情一区二区三区| 欧美电影在线免费观看| 国产精品国产a| 国产精品亚洲专一区二区三区| 欧美日韩亚洲综合| 亚洲日本韩国一区| 成人一级片在线观看| www久久精品| 秋霞成人午夜伦在线观看| 一本到高清视频免费精品| 久久精品一二三| 韩国精品主播一区二区在线观看 | 国产成人自拍在线| 欧美日韩国产综合草草| 国产精品电影一区二区| 国产成人综合亚洲网站| 精品国产麻豆免费人成网站| 天堂一区二区在线免费观看| 欧美吻胸吃奶大尺度电影| 综合久久久久久久| 99re热这里只有精品视频| 国产精品免费久久久久| 国产成人免费在线视频| 精品国内片67194| 精品一区二区综合| www国产精品av| 狠狠久久亚洲欧美| 久久久久久久性| 国产98色在线|日韩| 欧美激情在线看| 国产+成+人+亚洲欧洲自线| 国产拍揄自揄精品视频麻豆| 国产成人在线影院| 国产精品免费丝袜| 91在线视频官网| 一区二区三区在线播放| 欧美丝袜第三区| 日韩专区中文字幕一区二区| 日韩一区二区三区在线| 极品少妇xxxx精品少妇偷拍| 日韩欧美在线网站| 国产自产视频一区二区三区| 久久精品欧美一区二区三区麻豆 | 精品美女一区二区| 韩国午夜理伦三级不卡影院| 国产网红主播福利一区二区| 成人av中文字幕| 亚洲一区二区在线免费观看视频| 欧美影视一区二区三区| 蜜桃视频第一区免费观看| 欧美精品一区二区三区很污很色的 | 色婷婷久久久久swag精品| 亚洲国产精品麻豆| 日韩精品专区在线影院观看| 国产精品影视网| 一区二区三区毛片| 亚洲视频一二三| 欧美色国产精品| 久久aⅴ国产欧美74aaa| 国产精品久久久久久户外露出| 色成年激情久久综合| 青青国产91久久久久久| 中文字幕一区在线观看| 精品婷婷伊人一区三区三| 国产精品亚洲视频| 一级日本不卡的影视| 26uuu色噜噜精品一区二区| 99vv1com这只有精品| 美女视频网站黄色亚洲| 国产精品福利电影一区二区三区四区| 欧美性一级生活| 国产麻豆精品在线| 亚洲一级二级在线| 国产日韩av一区二区| 欧美日韩国产天堂| 成人av电影观看| 久久国产乱子精品免费女| 一区精品在线播放| 亚洲精品一区二区三区影院| 欧美影院一区二区| av午夜精品一区二区三区| 日本vs亚洲vs韩国一区三区二区| 国产精品久久久久久久久图文区| 欧美一区二区三区视频| 91黄视频在线| 成人av电影在线观看| 美女视频黄免费的久久| 亚洲图片欧美综合| 亚洲欧洲av在线| 久久精品视频网| 欧美成人艳星乳罩| 欧美久久久久免费| 日本韩国精品在线| 成人国产精品免费| 激情偷乱视频一区二区三区| 日本在线不卡视频一二三区| 亚洲一区二区三区四区在线观看 | 99精品视频在线免费观看| 精品一二三四区| 日韩在线一二三区| 亚洲成年人网站在线观看| 亚洲欧洲www| 国产精品久久久久久久裸模| 久久久av毛片精品| 久久综合精品国产一区二区三区| 欧美一级一区二区| 91精品国产一区二区三区| 精品视频在线免费| 欧美美女视频在线观看| 欧美性生交片4| 在线视频一区二区三| 色综合中文字幕国产 | 色一区在线观看| 99视频在线精品| 成人av在线资源网站| 不卡的av中国片| 成人av网址在线观看| 成人久久视频在线观看| 波多野结衣在线一区| 97久久久精品综合88久久| www.色综合.com| 日本高清不卡视频| 欧美日韩视频一区二区| 欧美一区二区三区在线观看视频| 欧美一区二区人人喊爽| 精品日韩欧美在线| 日本一区二区三区四区| 中文字幕一区二区在线观看| 亚洲蜜臀av乱码久久精品| 一区二区成人在线观看| 日韩av不卡在线观看| 久久成人羞羞网站| 成人av免费在线播放| 91久久久免费一区二区| 91.成人天堂一区| 久久你懂得1024| 亚洲视频一二三| 日韩av一区二| 成人免费看的视频| 欧美日韩不卡视频| 国产午夜一区二区三区| 亚洲同性同志一二三专区| 五月婷婷综合网| 国产精品系列在线观看| 色婷婷激情综合| 欧美成人精品1314www| 国产精品人成在线观看免费 | 成人网在线免费视频| 在线一区二区三区四区五区 | 91小宝寻花一区二区三区| 欧洲亚洲国产日韩| 久久亚洲精精品中文字幕早川悠里| 国产精品欧美综合在线| 日本在线观看不卡视频| 欧美日本韩国一区二区三区视频| 精品国产91乱码一区二区三区| 成人免费在线观看入口| 另类综合日韩欧美亚洲| 91福利在线看| 久久亚洲二区三区| 亚洲成人动漫在线观看| 东方欧美亚洲色图在线| 欧美日韩1区2区| 国产精品精品国产色婷婷| 免费看欧美女人艹b| 色一情一伦一子一伦一区| 精品国产99国产精品| 视频一区国产视频| 色综合久久六月婷婷中文字幕| 欧美xxxxx裸体时装秀| 午夜不卡在线视频| 97久久精品人人做人人爽50路| 精品久久久久久最新网址| 亚洲国产精品久久一线不卡| 97aⅴ精品视频一二三区| 久久久99久久| 国产在线不卡一区| 91精品国产综合久久久蜜臀图片| 亚洲美女电影在线| 成人动漫一区二区三区| 国产日产欧美一区| 九色综合狠狠综合久久| 制服丝袜在线91| 午夜精品影院在线观看| 在线免费一区三区| 亚洲精品一卡二卡| 91视频在线看| 亚洲欧洲www| 91麻豆国产福利在线观看| 国产精品久久久久久久久果冻传媒| 国产精品中文字幕欧美| 国产三级欧美三级日产三级99| 久草中文综合在线| 久久综合九色综合久久久精品综合 |