多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > 綜合技術 > 杭電ACM1671――Phone List~~字典樹

杭電ACM1671――Phone List~~字典樹

來源:程序員人生   發布時間:2015-06-04 07:35:43 閱讀次數:2524次

這1題,也是簡單的字典樹的利用,不過這里不是字母,而是數字。

題目的意思是判斷輸入的字符串會不會是其他字符串的前綴。就是這么的簡單。

下面是AC的代碼:

#include <iostream> #include <cstring> using namespace std; class node //結點的結構體 { public: node* P[10]; }; node* root; //定義根節點 int ans; //葉子結點數 void insert(char* str) //插入操作的函數 { int len = strlen(str); node *q, *p; q = root; for(int i = 0; i < len; i++) { int id = str[i] - '0'; if(q->P[id] == NULL) //該位置不存在,new1個 { p = new node; for(int j = 0; j < 10; j++) p->P[j] = NULL; q->P[id] = p; q = q->P[id]; } else //存在,直接等于他的后繼 q = q->P[id]; } } void fun(node *a) //遞歸找有多少個葉子結點 { int flag = 0; for(int i = 0; i < 10; i++) { if(a->P[i] != NULL) { flag = 1; break; } } if(!flag) //該結點是葉子結點,ans++ { ans++; return; } for(int j = 0; j < 10; j++) if(a->P[j] != NULL) fun(a->P[j]); } void dele(node *a) //刪除操作的函數,也是遞歸完成 { for(int i = 0; i < 10; i++) if(a->P[i] != NULL) dele(a->P[i]); delete a; } int main() { // freopen("data.txt", "r", stdin); int t, n; char str[15]; cin >> t; while(t--) { root = new node; ans = 0; for(int j = 0; j < 10; j++) //初始化根節點的指針數組P root->P[j] = NULL; cin >> n; for(int i = 0; i < n; i++) { cin >> str; insert(str); //插入 } fun(root); //算葉子結點數目 if(ans == n) //葉子結點等于輸入的n 的個數,則YES cout << "YES" << endl; else //否則NO cout << "NO" << endl; dele(root); //刪除 } return 0; }


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 亚洲成在线观看 | 色综合久久久久久久久久久 | 欧美老女人性视频 | 最近的中文字幕 | 亚洲天堂欧美 | 成年视频xxxxx在线网站 | 另类图片综合 | 亚洲国产成人99精品激情在线 | 亚洲日韩精品欧美一区二区一 | 亚洲性色永久网址 | 欧美xxxx做受欧美人妖 | 日本免费第一区二区三区 | 黄色三级生活片 | 亚洲另类天堂 | 成人精品一区二区久久 | 亚洲综合精品一区二区三区中文 | 那一个欧美一级毛片 | 亚洲成熟| 依人九九| 国产在线一区二区视频 | 大片刺激免费播放视频 | 亚洲精品免费视频 | аbt天堂资源在线官网 | 99成人免费视频 | 美女一级黄色片 | 国产69成人免费视频观看 | 精品videosex性欧美 | 最近中文字幕高清中文字幕在线看 | 国产成人一区二区三区视频免费蜜 | 免费网站在线观看高清版 | 欧美性受xxxx喷水性欧洲 | 欧美成人性色区 | 日本福利片秋霞国产午夜 | 精品成人一区二区 | 欧美日韩国产中文字幕 | 国产欧美在线一区二区三区 | 精品一久久香蕉国产二月 | 欧美日韩视频二区三区 | 成人精品视频在线观看 | 青娱乐久久| 羞羞视频在线观看入口 |