?? algo9-8.c
字號:
/* algo9-8.c 檢驗bo9-6.c的程序 */
#include"c1.h"
#define N 16 /* 數據元素個數 */
#define LENGTH 27 /* 結點的最大度+1(大寫英文字母) */
typedef struct
{
int ord;
}Others; /* 記錄的其它部分 */
#define Nil ' ' /* 定義結束符為空格(與教科書不同) */
#include"c9-5.h"
#include"bo9-6.c"
Status pr(Record *r)
{
printf("(%s,%d)",r->key.ch,r->others.ord);
return OK;
}
void main()
{
TrieTree t;
int i;
char s[MAXKEYLEN+1];
KeysType k;
Record *p;
Record r[N]={{{"CAI"},1},{{"CAO"},2},{{"LI"},3},{{"LAN"},4},
{{"CHA"},5},{{"CHANG"},6},{{"WEN"},7},{{"CHAO"},8},
{{"YUN"},9},{{"YANG"},10},{{"LONG"},11},{{"WANG"},12},
{{"ZHAO"},13},{{"LIU"},14},{{"WU"},15},{{"CHEN"},16}};
/* 數據元素(以教科書式9-24為例) */
InitDSTable(&t);
for(i=0;i<N;i++)
{
r[i].key.num=strlen(r[i].key.ch)+1;
r[i].key.ch[r[i].key.num]=Nil; /* 在關鍵字符串最后加結束符 */
p=SearchTrie(t,r[i].key);
if(!p)
InsertTrie(&t,&r[i]);
}
printf("按關鍵字符串的順序遍歷Trie樹(鍵樹):\n");
TraverseDSTable(t,pr);
printf("\n請輸入待查找記錄的關鍵字符串: ");
scanf("%s",s);
k.num=strlen(s)+1;
strcpy(k.ch,s);
k.ch[k.num]=Nil; /* 在關鍵字符串最后加結束符 */
p=SearchTrie(t,k);
if(p)
pr(p);
else
printf("沒找到");
printf("\n");
DestroyDSTable(&t);
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -