版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p><b> 報告</b></p><p> 姓 名: </p><p> 學(xué) 號: </p><p> 專 業(yè):
2、 </p><p> 聯(lián)系電話: </p><p> E m a il: </p><p><b> 報告一 拼寫檢測器</b></p><p><b> 實(shí)驗(yàn)題目</b></p><
3、p> 拼寫檢測器(Speller checker)</p><p><b> 問題描述</b></p><p> 1. load the words in the dictionary file(加載字典文件) </p><p> 2 .read the text file to be checked (讀取被檢測文件)</
4、p><p> 3. look up each word from the text file in the dictionary (逐個單詞的檢測其拼寫)</p><p> 4. print out the misspelled words in alphabetical order with their line numbers.(按字典順序打印出錯誤的單詞及其行號)例如某被檢測文件內(nèi)容
5、如下:</p><p> 顯然第二行的laanguage和第六行的ammong拼寫錯誤,輸出應(yīng)該:</p><p><b> ammong 6</b></p><p> laanguage 2</p><p><b> 概要設(shè)計(jì)</b></p><p><b
6、> 字典存儲結(jié)構(gòu)選擇</b></p><p> 由于所有的單詞的長短不一,單詞中字母重復(fù)的部分很多,如果用數(shù)組存儲字典的話很浪費(fèi)空間,所以考慮用樹存儲字典,相同部分只存儲一次,每一棵樹只存儲相同字母開頭的所有單詞,從上往下,依次存儲,孩子的腳標(biāo)與字母對應(yīng)(0-25號樹的樹根分別存放A-Z,26-51號樹的樹根分別存放a-z,其孩子也是一樣)。</p><p><
7、b> 樹的ADT 定義:</b></p><p> ADT DTree{</p><p> 數(shù)據(jù)對象:D={ai | ai屬于ElemSet,i=1,2,……,n n>=0}</p><p> 數(shù)據(jù)關(guān)系:若D為空集,則樹為空;若緊含一個數(shù)據(jù)元素,則數(shù)據(jù)關(guān)系為空,否則:</p><p> D中僅有一個稱為跟
8、(root)的數(shù)據(jù)元素,關(guān)系R沒有前驅(qū)。</p><p> 除根結(jié)點(diǎn)外,其余結(jié)點(diǎn)劃分m個互不相交的子集,對任意的子集Di,<root,xi>屬于R。</p><p><b> 基本操作:</b></p><p> InitTree(& T);</p><p><b> //建立空樹&
9、lt;/b></p><p> DestroyTree(& T);</p><p><b> //銷毀樹</b></p><p><b> Root(T) ;</b></p><p><b> //求樹跟</b></p><p>
10、 Insert(&T,x);</p><p> //將元素x插入樹中</p><p> Chile(T,x,i);</p><p> //求x結(jié)點(diǎn)的第i個孩子</p><p> ?。鼳DT DTree</p><p><b> 排序存儲結(jié)構(gòu)選擇</b></p>&l
11、t;p> 若選用數(shù)組,排序的時間復(fù)雜度很高,其單詞長短不一,選用鏈表。</p><p><b> 鏈表抽象數(shù)據(jù)定義</b></p><p> ADT LinkList{</p><p> 數(shù)據(jù)對象:D={ai| ai屬于ElemSet,i=1,2,……,n n>=0}</p><p> 數(shù)據(jù)關(guān)系:
12、R={<ai-1,ai>|ai-1,ai屬于D,i=1,2,……,n n>=0}</p><p><b> 基本操作:</b></p><p><b> Init(&L);</b></p><p><b> //構(gòu)造一個空鏈表</b></p><p&
13、gt; InsertInOrder(&L,x);</p><p> //將元素插入有序表中使之仍然有序</p><p> DisPlay();</p><p><b> //輸出結(jié)點(diǎn)信息</b></p><p> ?。鼳DT LinkList;</p><p><b>
14、 其他函數(shù)</b></p><p> 主函數(shù)main()。</p><p> 建字典函數(shù)CreateDTree()。</p><p> 檢測拼寫函數(shù)Checkspell()。</p><p><b> 詳細(xì)設(shè)計(jì)</b></p><p> 樹存儲字典,每個單詞的字母是一個結(jié)點(diǎn)
15、,而鏈表存放單詞及行號,用WordsLine結(jié)構(gòu)體單詞及行號,定義結(jié)點(diǎn)類ListNode、鏈表類LinkList、樹結(jié)點(diǎn)類DTreeNode、樹類DTree。</p><p><b> Stuct</b></p><p> struct WordsLine</p><p> {//結(jié)點(diǎn)類,存放錯誤的單詞及其行號</p>&l
16、t;p> string word;</p><p> int LineNumber;</p><p><b> };</b></p><p><b> 鏈表結(jié)點(diǎn)類</b></p><p> class ListNode //結(jié)點(diǎn)類定義</p><
17、p><b> {</b></p><p> friend class LinkList; //聲明鏈表類LinkList為友元類</p><p><b> private:</b></p><p> WordsLine data; //結(jié)點(diǎn)的數(shù)據(jù)域</p><p> ListN
18、ode* next; //結(jié)點(diǎn)的后繼指針域,存放后繼結(jié)點(diǎn)的地址</p><p><b> public:</b></p><p> ListNode();//構(gòu)造函數(shù)</p><p> ListNode(const WordsLine e):data(e),next(NULL){} //構(gòu)造函數(shù)</p><p>
19、; WordsLine& GetData(){return data;} //返回結(jié)點(diǎn)的數(shù)據(jù)值</p><p> ListNode* GetNext(){return next;} //返回結(jié)點(diǎn)的指針值</p><p> void SetData(WordsLine & e){data=e;} //設(shè)置結(jié)點(diǎn)的數(shù)據(jù)值</p><p&g
20、t; void SetNext(ListNode* ptr){next=ptr;} //設(shè)置結(jié)點(diǎn)的指針值</p><p> void DisPlay();//輸出結(jié)點(diǎn)的信息</p><p><b> };</b></p><p><b> 鏈表類</b></p><p> class
21、LinkList //鏈表類定義</p><p><b> { </b></p><p> friend class ListNode;</p><p><b> private:</b></p><p> ListNode *head; //鏈表的頭指針</p><p&
22、gt;<b> public:</b></p><p> LinkList(){head=new ListNode();} //構(gòu)造函數(shù),建立帶頭結(jié)點(diǎn)的空鏈表</p><p> LinkList(WordsLine& e){head=new ListNode(e);} //構(gòu)造函數(shù)</p><p> ~LinkList(){
23、LinkListClear();delete head;} //析構(gòu)函數(shù),刪除單鏈表</p><p> void LinkListClear();//將線性鏈表置為空表</p><p> ListNode* Head()const{return head;}</p><p> void InsertInOrder(WordsLine wordsLine);
24、 //插入元素后使鏈表依然有序遞增</p><p> bool IsEmpty(void)const{return head->next==NULL;} </p><p> void DisPlay();//輸出所有結(jié)點(diǎn)信息</p><p><b> };</b></p><p> //----------
25、--------------------------</p><p><b> 樹結(jié)點(diǎn)類</b></p><p> class DTreeNode</p><p> {friend class DTree;</p><p> char m_word; //每個單詞的各個字母</p><p&g
26、t; DTreeNode* (m_tp[52]);//52個孩子,指向個大小寫字母</p><p><b> public: </b></p><p> DTreeNode(); //構(gòu)造函數(shù)</p><p> DTreeNode(char word);//構(gòu)造函數(shù)</p><p> DTreeNode(c
27、har word,DTreeNode *tp); //構(gòu)造函數(shù)</p><p> char Getm_word(){return m_word;} //返回結(jié)點(diǎn)元素</p><p> DTreeNode*GetChild(char word);//返回當(dāng)前結(jié)點(diǎn)指向字符word的孩子</p><p> bool ExistNode(char word);//判斷
28、當(dāng)前節(jié)點(diǎn)有無存放x的孩子</p><p><b> };</b></p><p><b> 樹類</b></p><p> class DTree</p><p><b> {</b></p><p><b> private:<
29、;/b></p><p> DTreeNode* root;//樹根</p><p><b> public:</b></p><p> DTree():root(NULL){}//構(gòu)造函數(shù)</p><p> DTree(char word){root=new DTreeNode(word);}//構(gòu)造函數(shù)
30、,構(gòu)造以字母word為元素的根結(jié)點(diǎn)</p><p> DTreeNode* GetRoot(){return root;}//返回根結(jié)點(diǎn)</p><p> int GetPosition(char word);//返回待插入元素word的位置</p><p> void InsertWord(char* word);//將單詞word插入樹中</p>
31、;<p> bool ExistWord(const char *word);//判斷單詞word是否存在</p><p><b> };</b></p><p><b> 測試結(jié)果及分析</b></p><p> 程序名為speller.exe,運(yùn)行環(huán)境為Windows,在VC++6.0下測試通過。
32、程序執(zhí)行后顯示:</p><p><b> 輸入字典文件后:</b></p><p><b> 輸入被測試文件:</b></p><p> 再從一個英文網(wǎng)站上copy一段,將一些單詞故意改錯進(jìn)行測試:</p><p><b> 文件內(nèi)容為:</b></p>
33、<p><b> 測試結(jié)果為:</b></p><p> 由測試可以看出,程序的拼寫檢測功能還是很強(qiáng)大(加載了4962個單詞到詞典)</p><p><b> 源代碼</b></p><p> //ListNode.h</p><p> #ifndef HEAD_LINKNOD
34、E</p><p> #define HEAD_LINKNODE</p><p> //---------------------------</p><p> #include<iostream></p><p> //---------------------------</p><p> u
35、sing namespace std;</p><p> //-----------------------------</p><p> class LinkList;</p><p> struct WordsLine</p><p> {//結(jié)點(diǎn)類,存放錯誤的單詞及其行號</p><p> string
36、 word;</p><p> int LineNumber;</p><p><b> };</b></p><p> class ListNode //結(jié)點(diǎn)類定義</p><p><b> {</b></p><p> friend class
37、 LinkList; //聲明鏈表類LinkList為友元類</p><p><b> private:</b></p><p> WordsLine data; //結(jié)點(diǎn)的數(shù)據(jù)域</p><p> ListNode* next; //結(jié)點(diǎn)的后繼指針域,存放后繼結(jié)點(diǎn)的地址</p><p><b>
38、; public:</b></p><p> ListNode();//構(gòu)造函數(shù)</p><p> ListNode(const WordsLine e):data(e),next(NULL){} //構(gòu)造函數(shù)</p><p> WordsLine& GetData(){return data;} //返回結(jié)點(diǎn)的數(shù)據(jù)值</p&
39、gt;<p> ListNode* GetNext(){return next;} //返回結(jié)點(diǎn)的指針值</p><p> void SetData(WordsLine & e){data=e;} //設(shè)置結(jié)點(diǎn)的數(shù)據(jù)值</p><p> void SetNext(ListNode* ptr){next=ptr;} //設(shè)置結(jié)點(diǎn)的指針值</p&
40、gt;<p> void DisPlay();//輸出結(jié)點(diǎn)的信息</p><p><b> };</b></p><p> ListNode::ListNode()</p><p><b> {</b></p><p> data.LineNumber=0;</p>
41、;<p> next=NULL;</p><p><b> } </b></p><p> void ListNode::DisPlay()</p><p><b> {</b></p><p> cout<<data.word<<" &
42、quot;<<data.LineNumber<<endl;</p><p><b> }</b></p><p><b> #endif</b></p><p> //===================================</p><p> //Lin
43、kList.h</p><p> #ifndef HEAD_LINKLIST</p><p> #define HEAD_LINKLIST</p><p> //----------------------------</p><p> #include<iostream></p><p> #i
44、nclude"ListNode.h"</p><p> #include<string></p><p> //---------------------------</p><p> using namespace std;</p><p> //-------------------------&l
45、t;/p><p> class LinkList //鏈表類定義</p><p><b> { </b></p><p> friend class ListNode;</p><p><b> private:</b></p><p> ListNode *head;
46、 //鏈表的頭指針</p><p><b> public:</b></p><p> LinkList(){head=new ListNode();} //構(gòu)造函數(shù),建立帶頭結(jié)點(diǎn)的空鏈表</p><p> LinkList(WordsLine& e){head=new ListNode(e);} //構(gòu)造函數(shù)</p&g
47、t;<p> ~LinkList(){LinkListClear();delete head;} //析構(gòu)函數(shù),刪除單鏈表</p><p> void LinkListClear();//將線性鏈表置為空表</p><p> ListNode* Head()const{return head;}</p><p> void InsertIn
48、Order(WordsLine wordsLine); //插入元素后使鏈表依然有序遞增</p><p> bool IsEmpty(void)const{return head->next==NULL;} </p><p> void DisPlay();//輸出所有結(jié)點(diǎn)信息</p><p><b> };</b></p&g
49、t;<p> //------------------------------------</p><p> void LinkList::LinkListClear()</p><p><b> {</b></p><p> ListNode *p,*q;</p><p> p=head->
50、;next;</p><p> while(p) </p><p><b> {</b></p><p> q=p->next;</p><p><b> delete p;</b></p><p><b> p=q;</b></
51、p><p><b> }</b></p><p> head->next=NULL;</p><p><b> }</b></p><p> void LinkList::InsertInOrder(WordsLine wordsLine)</p><p><
52、b> {</b></p><p> ListNode *s=new ListNode(wordsLine);</p><p> ListNode *p=head;</p><p> while(p->next)</p><p> {//尋找當(dāng)wordsLine的單詞剛好大于當(dāng)前結(jié)點(diǎn)的單詞的結(jié)點(diǎn)</p&g
53、t;<p> //如果找到剛好大于的結(jié)點(diǎn),插入</p><p> if(strcmp(s->data.word.c_str(),p->next->data.word.c_str())<0) break;</p><p> else //否則當(dāng)結(jié)點(diǎn)不空時后移,空的時候插入</p><p> if(p->next-&g
54、t;next){p=p->next;}</p><p> else break;</p><p><b> }</b></p><p><b> //插入</b></p><p> s->next=p->next;</p><p> p->n
55、ext=s;</p><p><b> }</b></p><p> void LinkList::DisPlay()</p><p> {//調(diào)用結(jié)點(diǎn)類的成員函數(shù)ListNode::DisPlay()</p><p> ListNode *p=head->next;</p><p>
56、; if(!p) //表空則表明所有單詞拼寫正確,不用輸出,返回程序</p><p> {cout<<"All words are spelled correctly!!!"<<endl;return;} </p><p> //否則輸出錯誤的單詞信息</p><p> cout<<"The
57、incorrectly spelled words in alphabetical order with their linenumber are:"<<endl;</p><p> cout<<endl;</p><p><b> while(p)</b></p><p><b> {<
58、/b></p><p> p->DisPlay();</p><p> p=p->next;</p><p><b> }</b></p><p> cout<<endl;</p><p><b> }</b></p>&
59、lt;p><b> #endif</b></p><p> //===================================</p><p> // DTreeNode.h</p><p> #include<iostream></p><p> using namespace st
60、d;</p><p> class DTree;</p><p> class DTreeNode</p><p> {friend class DTree;</p><p> char m_word; //每個單詞的各個字母</p><p> DTreeNode* (m_tp[52]);//52個孩子,指
61、向個大小寫字母</p><p><b> public: </b></p><p> DTreeNode(); //構(gòu)造函數(shù)</p><p> DTreeNode(char word);//構(gòu)造函數(shù)</p><p> DTreeNode(char word,DTreeNode *tp); //構(gòu)造函數(shù)<
62、/p><p> char Getm_word(){return m_word;} //返回結(jié)點(diǎn)元素</p><p> DTreeNode*GetChild(char word);//返回當(dāng)前結(jié)點(diǎn)指向字符word的孩子</p><p> bool ExistNode(char word);//判斷當(dāng)前節(jié)點(diǎn)有無存放x的孩子</p><p>&l
63、t;b> };</b></p><p> DTreeNode::DTreeNode()</p><p><b> {//構(gòu)造函數(shù)</b></p><p> m_word='\0';</p><p> for(int i=0;i<52;i++) m_tp[i]=NULL;&
64、lt;/p><p><b> }</b></p><p> DTreeNode::DTreeNode(char word)</p><p><b> {//構(gòu)造函數(shù)</b></p><p> m_word=word;</p><p> for(int i=0;i<
65、52;i++) m_tp[i]=NULL;</p><p><b> }</b></p><p> DTreeNode* DTreeNode::GetChild(char word)</p><p> {//返回當(dāng)前結(jié)點(diǎn)指向字符word的孩子</p><p> int child=((word>='
66、A' && word<='Z')?word%'A':26+(word%'a'));</p><p> return m_tp[child];</p><p><b> }</b></p><p> bool DTreeNode::ExistNode(char w
67、ord)</p><p><b> {</b></p><p> int child=((word>='A' && word<='Z')?word%'A':26+(word%'a'));</p><p> return m_tp[child]!=N
68、ULL;</p><p><b> }</b></p><p><b> //DTree.h</b></p><p> #include<iostream></p><p> #include "DTreeNode.h"</p><p>
69、; using namespace std;</p><p> class DTree</p><p><b> {</b></p><p><b> private:</b></p><p> DTreeNode* root;//樹根</p><p><b&
70、gt; public:</b></p><p> DTree():root(NULL){}//構(gòu)造函數(shù)</p><p> DTree(char word){root=new DTreeNode(word);}//構(gòu)造函數(shù),構(gòu)造以字母word為元素的根結(jié)點(diǎn)</p><p> DTreeNode* GetRoot(){return root;}//返
71、回根結(jié)點(diǎn)</p><p> int GetPosition(char word);//返回待插入元素word的位置</p><p> void InsertWord(char* word);//將單詞word插入樹中</p><p> bool ExistWord(const char *word);//判斷單詞word是否存在</p><
72、p><b> };</b></p><p> void DTree::InsertWord(char* word)</p><p> {//將單詞word插入樹中,相同的樹中重復(fù)部分只存一次</p><p> if(!word || *word =='\0') return;</p><p>
73、; if(root==NULL || root->m_word=='\0') root=new DTreeNode(*word);</p><p> DTreeNode* tmp=root;</p><p><b> if(tmp)</b></p><p><b> {</b></p&g
74、t;<p><b> word++;</b></p><p> while(tmp)</p><p> {//將單詞word從第一個字母開始與root比較順著相同</p><p> //的結(jié)點(diǎn)走,直到下一個結(jié)點(diǎn)元素與單詞下一個字母不同</p><p> if(tmp->ExistNode(*
75、word))</p><p><b> {</b></p><p> tmp=tmp->GetChild(*word);</p><p><b> word++;</b></p><p><b> }</b></p><p> else
76、break;</p><p><b> }</b></p><p> while(word&&*word!='\0')</p><p> {//將所有沒有的部分插入樹中</p><p> int child=((*word>='A' && *w
77、ord<='Z')?*word%'A':26+(*word%'a'));</p><p> tmp->m_tp[child]=new DTreeNode(*word);</p><p> tmp=tmp->m_tp[child];</p><p><b> word++;</b&
78、gt;</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> bool DTree::ExistWord(const char *word)</p><p> {//
79、判斷單詞word是否存在</p><p> DTreeNode* tmp=root;</p><p> if(tmp&&tmp->m_word==(*word))</p><p> {//如果第一個字母與根結(jié)點(diǎn)值不同為false</p><p><b> word++;</b></p&
80、gt;<p> while(word&&*word!='\0'&&tmp&&tmp->ExistNode(*word))</p><p> {//將單詞word從第一個字母開始與root比較,順著相同</p><p> //的結(jié)點(diǎn)走,直到word結(jié)束且tmp!=0則為真</p><
81、p> tmp=tmp->GetChild(*word);</p><p><b> word++;</b></p><p><b> }</b></p><p> if(*word!='\0') return false;</p><p> else retur
82、n true;</p><p><b> }</b></p><p> else return false;</p><p><b> }</b></p><p> //speller.cpp</p><p> #include<iostream><
83、;/p><p> #include<fstream></p><p> #include<sstream></p><p> #include<string></p><p> #include"DTree.h"</p><p> #include"
84、;LinkList.h"</p><p> //-----------------------</p><p> using namespace std;</p><p> //-----------------------</p><p> LinkList L;//用一個鏈表儲存錯誤的單詞(方便排序)</p>
85、<p> //---------------------------</p><p> DTree m_dTree[52];//用一個數(shù)組存放所有樹,下標(biāo)與根結(jié)點(diǎn)字母對應(yīng)</p><p> //--------------------------</p><p> void CreateDTree();//加載字典文件,創(chuàng)建字典</p&g
86、t;<p> void CheckSpell();//檢測文檔拼寫,將錯誤的排序</p><p> //---------------------</p><p> void main()</p><p><b> {</b></p><p> CreateDTree();</p>
87、<p> CheckSpell();</p><p> L.DisPlay();//調(diào)用鏈表成員函數(shù),將所有錯誤的單詞信息輸出</p><p> system("pause");//暫停,便于用戶查看屏幕上輸出的錯誤單詞的信息</p><p><b> }</b></p><p>
88、 void CreateDTree()</p><p><b> {</b></p><p><b> //加載字典文檔</b></p><p> //--------------------------</p><p> string file;</p><p>
89、 cout<<"請輸入字典文件(包括完整路勁):"<<endl;</p><p> cin>>file;</p><p> ifstream in(file.c_str());</p><p> cout<<"字典加載中……請等待!?。?quot;<<endl;</
90、p><p> //--------------------------</p><p> for(string s;getline(in,s);)</p><p><b> {</b></p><p> char word[30];</p><p> istringstream sin(s)
91、;</p><p> char ch;int i=0;</p><p> while(sin>>ch) </p><p><b> {</b></p><p> word[i]=ch;</p><p><b> i++;</b></p>&
92、lt;p><b> }</b></p><p> word[i]='\0';</p><p> int pos_word;//定位單詞存放在哪顆樹中(先存大寫字母開頭的)</p><p> //0-25號樹的樹根分別存放A-Z,-51號樹的樹根分別存放a-z</p><p> pos_wo
93、rd=((*word>='A' && *word<='Z')?*word%'A':26+(*word%'a'));</p><p> m_dTree[pos_word].InsertWord(word);</p><p><b> }</b></p><
94、p><b> }</b></p><p> void CheckSpell()</p><p><b> {</b></p><p> //加載被檢測的文檔</p><p> //--------------------------</p><p> str
95、ing file;</p><p> cout<<"請輸入要檢測的文件(包括完整路勁):"<<endl;</p><p> cin>>file;</p><p> ifstream in(file.c_str());</p><p> cout<<"拼寫檢測
96、中……請等待!?。?quot;<<endl;</p><p> //--------------------------</p><p> int LineNumber=0;</p><p> for(string s;getline(in,s);)</p><p><b> {</b></p&
97、gt;<p> LineNumber++;//每讀一行,行數(shù)加</p><p> istringstream sin(s);</p><p> while(sin>>s)</p><p><b> {</b></p><p> char*tmp=(char*)s.c_str();//s
98、tring轉(zhuǎn)char*</p><p> while(*tmp!='\0')</p><p><b> {</b></p><p> int flag=1;//用來標(biāo)記當(dāng)行string中是否含多個單詞。為表示只有一個</p><p> char*word=tmp;//指向</p>&
99、lt;p> while((*tmp>='A'&&*tmp<='Z')||(*tmp>='a'&&*tmp<='z'))</p><p> {//直到當(dāng)前單詞完,獲得完整的一個單詞</p><p><b> ++tmp;</b><
100、/p><p><b> }</b></p><p> //以下代碼執(zhí)行如下工作</p><p> //-----------------------------------</p><p> //進(jìn)行檢測。如果單詞在字典中不存在則拼寫錯誤,將單詞及其行號入鏈表排序</p><p> //(用
101、鏈表將錯誤單詞按字母順序排序),最后將所有錯誤單詞輸出</p><p> //如果當(dāng)前行未結(jié)束,表明是遇到標(biāo)點(diǎn),當(dāng)前單詞結(jié)束,設(shè)置當(dāng)前單詞結(jié)束</p><p> //(后面可能仍然還有單詞)然后進(jìn)入下一個單詞</p><p> //如果字符串結(jié)束(當(dāng)前行當(dāng)前單詞以后沒有單詞)</p><p><b> //則開始下一行<
102、;/b></p><p> //-------------------------------------</p><p> if(*tmp!='\0')</p><p> {//如果當(dāng)前行未結(jié)束</p><p><b> flag=0;</b></p><p>
103、*tmp='\0';//設(shè)置當(dāng)前單詞結(jié)束</p><p><b> }</b></p><p> int pos_word;//定位單詞存放在哪顆樹中</p><p> bool big=false;</p><p> pos_word=((*word>='A' &&
104、amp; *word<='Z')?(*word%'A'):(26+(*word%'a')));</p><p> if(!m_dTree[pos_word].ExistWord(word))</p><p> {//單詞在字典中不存在</p><p> if((*word>='A' &
105、amp;& *word<='Z'))</p><p> {//將單詞的第一個大寫字母轉(zhuǎn)換成小寫的再檢測</p><p> char*tmp=word;</p><p> *tmp=*tmp+32;//首字母轉(zhuǎn)換成小寫的</p><p> pos_word=26+(*tmp%'a');<
106、;/p><p> big=m_dTree[pos_word].ExistWord(tmp);</p><p><b> }</b></p><p><b> if(!big)</b></p><p> {//當(dāng)單詞大小寫都不存在的的時候,拼寫錯誤,入鏈表排序</p><p&g
107、t; WordsLine wordsLine;//結(jié)構(gòu)體,存放單詞和所在行號</p><p> wordsLine.LineNumber=LineNumber;</p><p> wordsLine.word=word;</p><p> L.InsertInOrder(wordsLine);//調(diào)用鏈表的成員函數(shù)排序</p><p>
108、;<b> }</b></p><p><b> }</b></p><p> if(flag) break;//如果當(dāng)前行結(jié)束,則開始下一行</p><p><b> else </b></p><p><b> {</b></p>
109、<p> tmp++;//如果當(dāng)前行未結(jié)束,則進(jìn)入下一個單詞(先過濾掉標(biāo)點(diǎn))</p><p> while(*tmp!='\0'&&!((*tmp>='A'&&*tmp<='Z')||(*tmp>='a'&&*tmp<='z'))) </p
110、><p><b> tmp++; </b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)----集合運(yùn)算課程設(shè)計(jì)報告(c++)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——公交換乘系統(tǒng)(c++)
- 地圖著色問題-c++和數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告-中南大學(xué)
- 數(shù)據(jù)結(jié)構(gòu)(c++)課程設(shè)計(jì)報告--教學(xué)計(jì)劃編制問題
- 地圖著色問題-c++和數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告-中南大學(xué)
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計(jì)報告——航班信息查詢系統(tǒng)(c++)
- c語言與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計(jì)報告-北京地鐵查詢系統(tǒng)c++版
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)c語言課程設(shè)計(jì)報告之迷宮
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報告
評論
0/150
提交評論