双指针的常见用法及适用场景详解双指针是算法中一种高效且灵活的解题技巧,通过两个指针的协同操作降低时间复杂度和空间复杂度。以下是双指针的核心用法及适用场景分析:一、对撞指针(反向双指针)核心思想:两个指针分别从序列的两端向中间移动,适用于有序数组或可通过排序转化为有序的问题。在反向双指针里面right指向的是数组的长度,在循环的时候直接while(left
(PAT甲级)1019 General Palindromic Number 进制转换+回文数 (进制转换问题的实用技巧)
JaredYe
算法c++c语言pat考试
AnumberthatwillbethesamewhenitiswrittenforwardsorbackwardsisknownasaPalindromicNumber.Forexample,1234321isapalindromicnumber.Allsingledigitnumbersarepalindromicnumbers.Althoughpalindromicnumbersaremos
Windows 比较Excel文件助手
阿富软件园
电脑开源软件windows
在日常工作中,Excel是处理数据的常用工具,软件下载地址安装包但面对两份相似的工作表,如何快速准确地找出它们之间的差异,常常让许多Excel新手感到头疼。不过,现在有一款专为Excel小白设计的辅助工具,能够轻松解决这一难题,堪称Excel小白的福音。这款工具的使用方法非常简单,用户只需直接导入两份需要对比的工作表,软件便会自动启动其强大的数据对比功能。它能够主动且精准地定位出两份工作表中不同数
算法-基础算法-枚举算法(Python)
总裁余(余登武)
算法与数据结构算法leetcode
文章目录前言解题思路题目1两数之和2计数质数前言 枚举算法(EnumerationAlgorithm):也称为穷举算法,指的是按照问题本身的性质,一一列举出该问题所有可能的解,并在逐一列举的过程中,将它们逐一与目标状态进行比较以得出满足问题要求的解。在列举的过程中,既不能遗漏也不能重复。 枚举算法的核心思想是:通过列举问题的所有状态,将它们逐一与目标状态进行比较,从而得到满足条件的解。 由于
实数系的基本定理_11、实数的连续性(1)
weixin_39953102
实数系的基本定理
实数的连续性定理,图片来自网络。实数集合的连续性(简称实数的连续性或者实数的稠密性、实数的完备性)是实数系的一个基本特征,它是微积分学的坚实的理论基础.人们从不同的角度来描述和刻画实数集的完备性,得到了一连串的有关实数的连续性定理,其中包括:确界存在定理,闭区间套定理,单调有界收敛定理,聚点定理,有限覆盖定理,柯西准则,致密性定理等.定理1.1(确界存在定理,简称“确”)有上界数集必有上确界,有下
实数系的基本定理_七大实数理论与互推
weixin_39710288
实数系的基本定理
七大实数理论简介(一)确界原理定义1.1:是一个非空数集,是一个常数,若,有,则称是数集的一个上界。同理,若,有,则称是数集的一个下界。定义1.2:若是数集的一个上界,并且有,,满足,则称是数集的上确界。类似的,若是数集的一个下界,并且有,,满足,则称是数集的下确界。定理1.1:若数集有上确界,则上确界是唯一的。证明:使用反证法,若是数集的上确界,假设还有也是上确界。若,根据定义1.2的否定,取,
C++ string 类深度解析:字符串操作(拼接、查找、替换)
景彡先生
C++基础c++开发语言
在C++编程中,std::string是处理字符串的核心工具,它封装了动态字符串的内存管理,并提供了丰富的操作接口。本文将深入解析string类中最常用的字符串操作——拼接、查找、替换,通过原理分析和实战示例,帮助开发者高效掌握这些核心功能。一、string类基础:动态字符串的本质1.1核心特性动态内存管理:自动处理内存分配与释放,避免缓冲区溢出值语义:拷贝时复制内容,修改独立(区别于C风格字符数
数智助农 金融兴乡:中和农信双轮驱动农业现代化实践
雷焰财经
金融
植根三农服务最后一百米,中和农信以“小额信贷夯基,数智科技赋能”的创新实践,正在成为衔接中国小农户与现代农业的关键纽带。在我国小农户占比超80%的基本国情下,面对农村互联网普及率仅60%的数字鸿沟挑战,中和农信依托深耕多年建立的毛细血管式服务网络(5800名村级站长覆盖220万亩耕地)、科技金融双引擎(自研中和金服APP与乡助农技平台)及生态化服务闭环,累计服务480万农户,覆盖23省550县域。
基于Python的京东商品信息采集实战:用Playwright+Pandas打造高效数据抓取工具
Python爬虫项目
2025年爬虫实战项目pythonpandas开发语言爬虫游戏笔记
一、项目背景与目标在当今电商生态中,价格、销量、评论等商品信息对用户和商家来说至关重要。无论是做数据分析、电商监控,还是构建商品推荐系统,第一步都是:获取真实的商品数据。本项目以京东商城搜索结果页为目标,通过构建一个高效、可复用的商品信息采集爬虫系统,实现对商品名称、价格、店铺、评论数、链接等核心信息的提取。二、技术路线概述我们采用如下技术架构:模块技术选型浏览器自动化Playwright(现代、
Python爬虫:爬取物流公司运输数据与包裹跟踪信息
Python爬虫项目
python爬虫开发语言数据挖掘旅游
一、前言随着电商行业的蓬勃发展,物流服务已成为不可或缺的一部分。消费者对物流运输状态的关注越来越高,实时查询包裹的运输进度成为日常生活的一部分。物流公司爬虫正是为了自动化获取物流公司的运输数据和包裹的跟踪信息,帮助消费者、商家以及物流公司本身进行数据分析、优化物流链条和提高客户体验。本文将详细介绍如何使用Python爬虫从多个物流公司网站或API接口中抓取运输数据、包裹跟踪信息以及相关的统计分析数
UnityAPI——Math数学函数类、Random生成随机数类、OnMouseEventFunction 鼠标回调事件
WX呦
c#unity开发语言unity引擎
一、Mathf数学函数类1、三角函数介绍Unity的所有三角函数都以弧度为单位,提供了如下函数:Sin、Cos、Tan:计算正弦、余弦和正切值。Asin、Acos、Atan:计算反正弦、反余弦和反正切值。Atan2:计算两点之间的角度,考虑了X轴与2D向量之间的角度。应用假设您需要计算一个物体在圆周路径上的移动,您可以使用Mathf.Sin和Mathf.Cos来计算其在X和Y轴上的位置。float
设计的“第一性原理”:从Photoshop与Premiere Pro的AI革新谈起
最近有机会深入体验了一套来自英国ParvisSchoolofEconomicsandMusic的Adobe正版教育订阅,在把玩研究CreativeCloud全家桶的过程中,确实挖到了一些宝贝,感触颇深,忍不住想立刻和大家聊聊。先简单说下这套订阅给我的直观感受:它的FireflyAI积分是我见过最慷慨的,每周足足有1500点;授权设备数也达到了4台,可惜我囊中羞涩,并没有那么多设备去一一验证。最让我
安装wordpress报错(完美解决)
光头程序员em
wordpress报错
#错误1#YourserverisrunningPHPversion7.2.1butWordPress6.7.1requiresatleast7.2.24.这是因为wordpress6.7.1需要7.2.24及以上版本,解决方法就是下载低版本wordpress或者升级高版本的php运行环境#错误2#不能选择数据库可以连接到数据库服务器(这说明您的用户名和密码正确),但是不能选择wordpress数
Qt界面编程(五)
明阿明
qtlinux
一、Qt的网络通信使用网络通信模块前,要在.pro文件中添加network模块。QUdpScoket类是Qt对UDP协议的封装:1、创建QUdpSocket对象2、绑定IP的端口号3、发送数据:qint64writeDatagram(constchar*data,qint64len,constQHostAddress&host,quint16port);data:待发送数据的首地址len:待发送数
【力扣hot100】python刷题笔记之哈希
Animato.
哈希算法leetcode笔记
1.两数之和(简单)题目描述:给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。你可以按任意顺序返回答案。示例:解法一:暴力解法:双层循环(这里就不给代码了)解法二:哈希表(时间复杂度O(n))算法思路:(1)先创建一个空字典当做哈希表来存储已经遍历过的
矩阵的行列式和逆矩阵的行列式的关系
音程
数学矩阵线性代数
矩阵的行列式和它的逆矩阵的行列式之间有明确的数学关系。我们来详细解释这个关系。✅前提条件:要讨论逆矩阵的行列式,首先必须满足矩阵是可逆的(即:非奇异矩阵),也就是说:矩阵AAA是一个方阵(行数等于列数)且其行列式det(A)≠0\det(A)\neq0det(A)=0核心公式:设AAA是一个n×nn\timesnn×n的可逆矩阵,则其逆矩阵A−1A^{-1}A−1存在,并且满足以下关系:det
iOS 抓包实战:时间戳偏差导致的数据同步异常排查记录
00后程序员张
httpudphttpswebsocket网络安全网络协议tcp/ip
“这条数据不是我填的”“我的更新被覆盖了”“两个设备显示不一致”——这些是产品上线后最令人头疼的反馈。最近我们在一次用户同步问题排查中,发现表面是“数据丢失”问题,实则是多端数据提交时间戳处理不一致,导致后台认为老数据为新,覆盖了正确内容。这类问题通常日志无法直接反映,需要从网络请求行为层级来全面还原。本文是一次跨平台同步数据错乱排查的抓包实录,目标是展示如何用多工具组合方式,精确还原并定位导致数
verilog ascii码 0-99翻译成16进制数
LEEE@FPGA
FPGA学习记录fpga开发
VerilogASCII码转16进制数(0-99)moduleascii_to_hex(inputclk,inputrst_n,input[7:0]ascii_high,//十位数的ASCII码input[7:0]ascii_low,//个位数的ASCII码outputreg[7:0]hex_data//输出的16进制数);reg[7<
什么是Sentinel? 以及优点
肘击鸣的百k路
sentinel
Sentinel是阿里巴巴开源的轻量级流量治理与系统保护组件,专注于微服务架构下的实时流量控制、熔断降级和系统稳定性保障。其核心目标是通过动态规则管理防止服务因高并发、突发流量或依赖故障导致雪崩崩溃。⚙️Sentinel的核心功能流量控制基于QPS(每秒请求数)或并发线程数限制资源访问,支持直接拒绝、匀速排队(漏桶算法)、慢启动(令牌桶算法)等策略。细粒度控制:可针对特定接口、方法甚至热点参数(如
DataX(2)—— 核心流程
申尧强
datax
DataX的核心执行流程:初始化阶段创建JobContainer容器(主控进程)加载配置,初始化reader/writer插件准备阶段调用reader/writer的prepare()方法执行数据源和目标端的准备工作任务切分阶段根据channel数切分reader任务根据reader切分结果切分writer任务合并生成最终task配置调度执行阶段分配task到各个taskGroup启动TaskGr
PIC16F877A与Proteus仿真-GPIO寄存器与配置
视觉与物联智能
物联网全栈开发实战PIC16F877Aproteus嵌入式物联网仿真
GPIO寄存器与配置在本文中,我们将讨论PIC控制器的端口配置。我们将使用PIC16F877A作为参考,同样适用于其他PIC系列控制器。在本文结束时,你将熟悉PICGPIO以及用于配置和访问GPIO的相关寄存器。1、GPIO寄存器任何控制器的基本和重要特性是可用于连接外围设备的gpio数量。PIC16F877A的33-gpio分为五个端口,即PORTA-PORTE,如下表所示:端口方向寄存器引脚数
从指令设计到系统集成:提示词工具链与GPTs插件的效率革命
charles666666
人工智能自然语言处理语言模型知识图谱transformer
一、提示词工程工具链:概念与架构解析1.1为什么需要工具链?大模型交互的本质是“指令设计”,但人工编写提示词存在三大痛点:效率低(重复调试耗时)、质量不稳定(依赖个人经验)、复用性差(场景迁移成本高)。例如,某电商企业要求AI生成500种商品描述时,人工逐条调整提示词需耗费数周,且风格难以统一。工具链的价值在于通过模块化设计与自动化流程解决上述问题。其核心架构包含三个层级:需求解析层:将用户需求拆
Launcher3源码分析(CellLayout)
pnying
CellLayout是workspace的屏幕。CellLayout中的一些重要属性:intmCellWidth;intmCellHeight;//每一个屏幕的行列数intmCountX;//每一行的item个数intmCountY;//每一列的item个数//item之间的距离intmWidthGap;//item之间的宽度intmHeightGap;//item之间的高度构造方法publicC
apache 安装linux windows
墙头上一根草
apacheinuxwindows
linux安装Apache 有两种方式一种是手动安装通过二进制的文件进行安装,另外一种就是通过yum 安装,此中安装方式,需要物理机联网。以下分别介绍两种的安装方式
通过二进制文件安装Apache需要的软件有apr,apr-util,pcre
1,安装 apr 下载地址:htt
fill_parent、wrap_content和match_parent的区别
Cb123456
match_parentfill_parent
fill_parent、wrap_content和match_parent的区别:
1)fill_parent
设置一个构件的布局为fill_parent将强制性地使构件扩展,以填充布局单元内尽可能多的空间。这跟Windows控件的dockstyle属性大体一致。设置一个顶部布局或控件为fill_parent将强制性让它布满整个屏幕。
2) wrap_conte
网页自适应设计
天子之骄
htmlcss响应式设计页面自适应
网页自适应设计
网页对浏览器窗口的自适应支持变得越来越重要了。自适应响应设计更是异常火爆。再加上移动端的崛起,更是如日中天。以前为了适应不同屏幕分布率和浏览器窗口的扩大和缩小,需要设计几套css样式,用js脚本判断窗口大小,选择加载。结构臃肿,加载负担较大。现笔者经过一定时间的学习,有所心得,故分享于此,加强交流,共同进步。同时希望对大家有所
[sql server] 分组取最大最小常用sql
一炮送你回车库
SQL Server
--分组取最大最小常用sql--测试环境if OBJECT_ID('tb') is not null drop table tb;gocreate table tb( col1 int, col2 int, Fcount int)insert into tbselect 11,20,1 union allselect 11,22,1 union allselect 1
ImageIO写图片输出到硬盘
3213213333332132
javaimage
package awt;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import javax.imagei
自己的String动态数组
宝剑锋梅花香
java动态数组数组
数组还是好说,学过一两门编程语言的就知道,需要注意的是数组声明时需要把大小给它定下来,比如声明一个字符串类型的数组:String str[]=new String[10]; 但是问题就来了,每次都是大小确定的数组,我需要数组大小不固定随时变化怎么办呢? 动态数组就这样应运而生,龙哥给我们讲的是自己用代码写动态数组,并非用的ArrayList 看看字符
pinyin4j工具类
darkranger
.net
pinyin4j工具类Java工具类 2010-04-24 00:47:00 阅读69 评论0 字号:大中小
引入pinyin4j-2.5.0.jar包:
pinyin4j是一个功能强悍的汉语拼音工具包,主要是从汉语获取各种格式和需求的拼音,功能强悍,下面看看如何使用pinyin4j。
本人以前用AscII编码提取工具,效果不理想,现在用pinyin4j简单实现了一个。功能还不是很完美,
StarUML学习笔记----基本概念
aijuans
UML建模
介绍StarUML的基本概念,这些都是有效运用StarUML?所需要的。包括对模型、视图、图、项目、单元、方法、框架、模型块及其差异以及UML轮廓。
模型、视与图(Model, View and Diagram)
&
Activiti最终总结
avords
Activiti id 工作流
1、流程定义ID:ProcessDefinitionId,当定义一个流程就会产生。
2、流程实例ID:ProcessInstanceId,当开始一个具体的流程时就会产生,也就是不同的流程实例ID可能有相同的流程定义ID。
3、TaskId,每一个userTask都会有一个Id这个是存在于流程实例上的。
4、TaskDefinitionKey和(ActivityImpl activityId
从省市区多重级联想到的,react和jquery的差别
bee1314
jqueryUIreact
在我们的前端项目里经常会用到级联的select,比如省市区这样。通常这种级联大多是动态的。比如先加载了省,点击省加载市,点击市加载区。然后数据通常ajax返回。如果没有数据则说明到了叶子节点。 针对这种场景,如果我们使用jquery来实现,要考虑很多的问题,数据部分,以及大量的dom操作。比如这个页面上显示了某个区,这时候我切换省,要把市重新初始化数据,然后区域的部分要从页面
Eclipse快捷键大全
bijian1013
javaeclipse快捷键
Ctrl+1 快速修复(最经典的快捷键,就不用多说了)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ 复制当前行到上一行(复制增加)Alt+↓ 当前行和下面一行交互位置(特别实用,可以省去先剪切,再粘贴了)Alt+↑ 当前行和上面一行交互位置(同上)Alt+← 前一个编辑的页面Alt+→ 下一个编辑的页面(当然是针对上面那条来说了)Alt+En
js 笔记 函数
征客丶
JavaScript
一、函数的使用
1.1、定义函数变量
var vName = funcation(params){
}
1.2、函数的调用
函数变量的调用: vName(params);
函数定义时自发调用:(function(params){})(params);
1.3、函数中变量赋值
var a = 'a';
var ff
【Scala四】分析Spark源代码总结的Scala语法二
bit1129
scala
1. Some操作
在下面的代码中,使用了Some操作:if (self.partitioner == Some(partitioner)),那么Some(partitioner)表示什么含义?首先partitioner是方法combineByKey传入的变量,
Some的文档说明:
/** Class `Some[A]` represents existin
java 匿名内部类
BlueSkator
java匿名内部类
组合优先于继承
Java的匿名类,就是提供了一个快捷方便的手段,令继承关系可以方便地变成组合关系
继承只有一个时候才能用,当你要求子类的实例可以替代父类实例的位置时才可以用继承。
在Java中内部类主要分为成员内部类、局部内部类、匿名内部类、静态内部类。
内部类不是很好理解,但说白了其实也就是一个类中还包含着另外一个类如同一个人是由大脑、肢体、器官等身体结果组成,而内部类相
盗版win装在MAC有害发热,苹果的东西不值得买,win应该不用
ljy325
游戏applewindowsXPOS
Mac mini 型号: MC270CH-A RMB:5,688
Apple 对windows的产品支持不好,有以下问题:
1.装完了xp,发现机身很热虽然没有运行任何程序!貌似显卡跑游戏发热一样,按照那样的发热量,那部机子损耗很大,使用寿命受到严重的影响!
2.反观安装了Mac os的展示机,发热量很小,运行了1天温度也没有那么高
&nbs
读《研磨设计模式》-代码笔记-生成器模式-Builder
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
/**
* 生成器模式的意图在于将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示(GoF)
* 个人理解:
* 构建一个复杂的对象,对于创建者(Builder)来说,一是要有数据来源(rawData),二是要返回构
JIRA与SVN插件安装
chenyu19891124
SVNjira
JIRA安装好后提交代码并要显示在JIRA上,这得需要用SVN的插件才能看见开发人员提交的代码。
1.下载svn与jira插件安装包,解压后在安装包(atlassian-jira-subversion-plugin-0.10.1)
2.解压出来的包里下的lib文件夹下的jar拷贝到(C:\Program Files\Atlassian\JIRA 4.3.4\atlassian-jira\WEB
常用数学思想方法
comsci
工作
对于搞工程和技术的朋友来讲,在工作中常常遇到一些实际问题,而采用常规的思维方式无法很好的解决这些问题,那么这个时候我们就需要用数学语言和数学工具,而使用数学工具的前提却是用数学思想的方法来描述问题。。下面转帖几种常用的数学思想方法,仅供学习和参考
函数思想
把某一数学问题用函数表示出来,并且利用函数探究这个问题的一般规律。这是最基本、最常用的数学方法
pl/sql集合类型
daizj
oracle集合typepl/sql
--集合类型
/*
单行单列的数据,使用标量变量
单行多列数据,使用记录
单列多行数据,使用集合(。。。)
*集合:类似于数组也就是。pl/sql集合类型包括索引表(pl/sql table)、嵌套表(Nested Table)、变长数组(VARRAY)等
*/
/*
--集合方法
&n
[Ofbiz]ofbiz初用
dinguangx
电商ofbiz
从github下载最新的ofbiz(截止2015-7-13),从源码进行ofbiz的试用
1. 加载测试库
ofbiz内置derby,通过下面的命令初始化测试库
./ant load-demo (与load-seed有一些区别)
2. 启动内置tomcat
./ant start
或
./startofbiz.sh
或
java -jar ofbiz.jar
&
结构体中最后一个元素是长度为0的数组
dcj3sjt126com
cgcc
在Linux源代码中,有很多的结构体最后都定义了一个元素个数为0个的数组,如/usr/include/linux/if_pppox.h中有这样一个结构体: struct pppoe_tag { __u16 tag_type; __u16 tag_len; &n
Linux cp 实现强行覆盖
dcj3sjt126com
linux
发现在Fedora 10 /ubutun 里面用cp -fr src dest,即使加了-f也是不能强行覆盖的,这时怎么回事的呢?一两个文件还好说,就输几个yes吧,但是要是n多文件怎么办,那还不输死人呢?下面提供三种解决办法。 方法一
我们输入alias命令,看看系统给cp起了一个什么别名。
[root@localhost ~]# aliasalias cp=’cp -i’a
Memcached(一)、HelloWorld
frank1234
memcached
一、简介
高性能的架构离不开缓存,分布式缓存中的佼佼者当属memcached,它通过客户端将不同的key hash到不同的memcached服务器中,而获取的时候也到相同的服务器中获取,由于不需要做集群同步,也就省去了集群间同步的开销和延迟,所以它相对于ehcache等缓存来说能更好的支持分布式应用,具有更强的横向伸缩能力。
二、客户端
选择一个memcached客户端,我这里用的是memc
Search in Rotated Sorted Array II
hcx2013
search
Follow up for "Search in Rotated Sorted Array":What if duplicates are allowed?
Would this affect the run-time complexity? How and why?
Write a function to determine if a given ta
Spring4新特性——更好的Java泛型操作API
jinnianshilongnian
spring4generic type
Spring4新特性——泛型限定式依赖注入
Spring4新特性——核心容器的其他改进
Spring4新特性——Web开发的增强
Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC
Spring4新特性——Groovy Bean定义DSL
Spring4新特性——更好的Java泛型操作API
Spring4新
CentOS安装JDK
liuxingguome
centos
1、行卸载原来的:
[root@localhost opt]# rpm -qa | grep java
tzdata-java-2014g-1.el6.noarch
java-1.7.0-openjdk-1.7.0.65-2.5.1.2.el6_5.x86_64
java-1.6.0-openjdk-1.6.0.0-11.1.13.4.el6.x86_64
[root@localhost
二分搜索专题2-在有序二维数组中搜索一个元素
OpenMind
二维数组算法二分搜索
1,设二维数组p的每行每列都按照下标递增的顺序递增。
用数学语言描述如下:p满足
(1),对任意的x1,x2,y,如果x1<x2,则p(x1,y)<p(x2,y);
(2),对任意的x,y1,y2, 如果y1<y2,则p(x,y1)<p(x,y2);
2,问题:
给定满足1的数组p和一个整数k,求是否存在x0,y0使得p(x0,y0)=k?
3,算法分析:
(
java 随机数 Math与Random
SaraWon
javaMathRandom
今天需要在程序中产生随机数,知道有两种方法可以使用,但是使用Math和Random的区别还不是特别清楚,看到一篇文章是关于的,觉得写的还挺不错的,原文地址是
http://www.oschina.net/question/157182_45274?sort=default&p=1#answers
产生1到10之间的随机数的两种实现方式:
//Math
Math.roun
oracle创建表空间
tugn
oracle
create temporary tablespace TXSJ_TEMP
tempfile 'E:\Oracle\oradata\TXSJ_TEMP.dbf'
size 32m
autoextend on
next 32m maxsize 2048m
extent m
使用Java8实现自己的个性化搜索引擎
yangshangchuan
javasuperword搜索引擎java8全文检索
需要对249本软件著作实现句子级别全文检索,这些著作均为PDF文件,不使用现有的框架如lucene,自己实现的方法如下:
1、从PDF文件中提取文本,这里的重点是如何最大可能地还原文本。提取之后的文本,一个句子一行保存为文本文件。
2、将所有文本文件合并为一个单一的文本文件,这样,每一个句子就有一个唯一行号。
3、对每一行文本进行分词,建立倒排表,倒排表的格式为:词=包含该词的总行数N=行号