青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 183,  comments - 10,  trackbacks - 0

前綴匹配

網絡層的數據報網絡,在路由器轉發功能實現中會用到前綴匹配,即是對 IP 地址與路由表中的目的地址范圍的公共部分進行前綴匹配。
由于有的前綴存在包含的問題,對有些 IP 地址會造成多重匹配,短的匹配會造成 IP 的轉發錯誤。
所以可以遵循 最長前綴匹配原則 進行匹配。

首先做一個 ip 轉換的實現
從 unsigned int 32 位整型數到 ip 字符串的轉換
從 ip 字符串到 unsigned int 32 位整型數的轉換

 1 #include <cstdio>
 2 #include <iostream>
 3 #include <string>
 4 using namespace std;
 5 
 6 string uintToIp(unsigned nip)
 7 {
 8     int t[4];
 9     for (int i = 3; i >= 0--i)
10     {
11         t[i] = nip % 256;
12         nip /= 256;
13     }
14     string ret;
15     char s[4];
16     for (int i = 0; i < 3++i)
17     {
18         ret += itoa(t[i], s, 10);
19         ret += '.';
20     }
21     return ret += itoa(t[3], s, 10);
22 }
23 
24 unsigned ipToUint(const string& ip)
25 {
26     unsigned ret = 0;
27     string::size_type st1 = 0, st2 = 0;
28     string t;
29     while ((st2 = ip.find('.', st1)) != string::npos)
30     {
31         t = ip.substr(st1, st2 - st1);
32         ret = ret * 256 + atoi(t.c_str());
33         st1 = st2 + 1;
34     }
35     t = ip.substr(st1, ip.size() - st2);
36     return ret = ret * 256 + atoi(t.c_str());
37 }
38 
39 int main()
40 {
41     unsigned nip;
42     string   ip;
43     while (cin >> nip)
44     {
45         cout << uintToIp(nip) << endl;
46 
47         cin >> ip;
48         cout << ipToUint(ip)  << endl;
49     }
50     return 0;
51 }

 

ip 的形式有三種
·點式十進制
·二進制
·unsigned
它們之間的轉換以 unsigned 為橋梁

前綴匹配的實現
利用異或,與前綴進行異或,如果得到的結果的相應位都為 0 則說明匹配成功,否則沒有匹配成功。
------------------------------
前綴匹配   鏈路接口
xxxxxxxxxxx   0
xxxxxxxxxxxxxx  1
xxxxxxxxxxx   2
其他    3
------------------------------
前綴匹配也可以直接尋找在轉發表里的排序前綴中,第一個大于待匹配的 ip 的那個前綴即是前綴匹配成功的。

 

  1 #include <cstdio>
  2 #include <iostream>
  3 #include <string>
  4 #include <map>
  5 using namespace std;
  6 
  7 string uintToIp(unsigned nip)
  8 {
  9     int t[4];
 10     for (int i = 3; i >= 0--i)
 11     {
 12         t[i] = nip % 256;
 13         nip /= 256;
 14     }
 15     string ret;
 16     char s[4];
 17     for (int i = 0; i < 3++i)
 18     {
 19         ret += itoa(t[i], s, 10);
 20         ret += '.';
 21     }
 22     return ret += itoa(t[3], s, 10);
 23 }
 24 
 25 unsigned ipToUint(const string& ip)
 26 {
 27     unsigned ret = 0;
 28     string::size_type st1 = 0, st2 = 0;
 29     string t;
 30     while ((st2 = ip.find('.', st1)) != string::npos)
 31     {
 32         t = ip.substr(st1, st2 - st1);
 33         ret = ret * 256 + atoi(t.c_str());
 34         st1 = st2 + 1;
 35     }
 36     t = ip.substr(st1, ip.size() - st2);
 37     return ret = ret * 256 + atoi(t.c_str());
 38 }
 39 
 40 unsigned binaryIpToUint(const string& bip)
 41 {
 42     unsigned ret = 0;
 43     for (string::size_type i = 0; i != bip.size(); ++i)
 44     {
 45         ret = ret * 2 + (bip[i] - '0');
 46     }
 47     return ret;
 48 }
 49 
 50 string uintToBinaryIp(unsigned uip)
 51 {
 52     string ret;
 53     for (int i = 0; i != 32++i)
 54     {
 55         if (uip >= (1 << 31))
 56         {
 57             ret += '1';
 58         }
 59         else
 60         {
 61             ret += '0';
 62         }
 63         uip <<= 1;
 64     }
 65     return ret;
 66 }
 67 
 68 string binaryIpToIp(const string& bip)
 69 {
 70     return uintToIp(binaryIpToUint(bip));
 71 }
 72 
 73 string ipToBinaryIp(const string& ip)
 74 {
 75     return uintToBinaryIp(ipToUint(ip));
 76 }
 77 
 78 //unsigned findNonZeroBitNo(unsigned prefix)
 79 //{
 80 //    unsigned ret = 0;
 81 //    unsigned mask = 1 << 31;
 82 //    while ((prefix & mask) == 0)
 83 //    {
 84 //        ++ret;
 85 //        prefix <<= 1;
 86 //    }
 87 //    return ret;
 88 //}
 89 
 90 bool marchPrefix(unsigned nip, const string& prefix)
 91 {
 92     string ip = uintToBinaryIp(nip);
 93     return ip.substr(0, prefix.size()) == prefix;
 94 }
 95 
 96 struct Prefix
 97 {
 98     string bip;
 99     Prefix(const string& s) : bip(s) {}
100 };
101 
102 bool operator < (const Prefix& lhs, const Prefix& rhs)
103 {
104     if (lhs.bip < rhs.bip)
105     {
106         if (rhs.bip.find(lhs.bip) != string::npos)
107         {
108             return false;
109         }
110         else
111         {
112             return true;
113         }
114     }
115     else if (lhs.bip > rhs.bip)
116     {
117         if (lhs.bip.find(rhs.bip) != string::npos)
118         {
119             return true;
120         }
121         else
122         {
123             return false;
124         }
125     }
126     else
127     {
128         return false;
129     }
130 }
131 
132 bool operator == (const Prefix& lhs, const Prefix& rhs)
133 {
134     return lhs.bip == rhs.bip;
135 }
136 
137 int main()
138 {
139     map<Prefix, unsigned> forwardingtable;
140     forwardingtable[Prefix("110010000001011100010")] = 0;
141     forwardingtable[Prefix("110010000001011100011000")] = 1;
142     forwardingtable[Prefix("110010000001011100011")] = 2;
143 
144     for (map<Prefix, unsigned>::const_iterator cit = forwardingtable.begin(); cit != forwardingtable.end(); ++cit)
145     {
146         cout << cit->first.bip << '\t' << cit->second << endl;
147     }
148 
149     unsigned nip;
150     string   ip;
151     while (cin >> ip)
152     {
153         nip = ipToUint(ip);
154         //cout << nip << endl;
155         unsigned linkinterface = 3;
156         for (map<Prefix, unsigned>::const_iterator cit = forwardingtable.begin(); cit != forwardingtable.end(); ++cit)
157         {
158             if (marchPrefix(nip, cit->first.bip) == true)
159             {
160                 linkinterface = cit->second;
161                 break;
162             }
163         }
164         cout << linkinterface << endl;
165     }
166     return 0;
167 }



posted on 2011-06-17 14:36 unixfy 閱讀(813) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲三级免费电影| 久久综合中文字幕| 亚洲视频在线观看一区| 另类人畜视频在线| 亚洲午夜一区| 国产麻豆午夜三级精品| 久久精品国产清高在天天线 | 在线观看视频欧美| 亚洲福利国产精品| 欧美国产在线视频| 欧美激情精品久久久久久免费印度| 国产亚洲成精品久久| 噜噜爱69成人精品| 久久综合五月| 亚洲一区在线看| 久久美女性网| 亚洲婷婷在线| 免费观看30秒视频久久| 在线一区二区视频| 久久成人久久爱| 亚洲欧美日韩一区在线观看| 久久一区二区三区国产精品| 亚洲欧美国内爽妇网| 美女诱惑黄网站一区| 欧美一级二级三级蜜桃| 欧美激情精品久久久久久黑人| 欧美一区=区| 欧美精品国产精品| 欧美激情中文不卡| 亚洲电影免费观看高清| 久久国产88| 欧美精品在线一区| 欧美韩日一区二区三区| 激情五月婷婷综合| 久久精品72免费观看| 久久久精品午夜少妇| 国产在线精品二区| 久久gogo国模裸体人体| 亚洲日本一区二区三区| 一本色道久久综合亚洲精品高清 | 亚洲视频一区在线| 在线性视频日韩欧美| 欧美日本视频在线| 日韩亚洲成人av在线| 中文久久精品| 国产精品欧美一区二区三区奶水| av不卡在线观看| 欧美在现视频| 永久免费精品影视网站| 欧美国产日韩精品免费观看| 最新日韩在线视频| 午夜国产一区| 影音先锋亚洲精品| 欧美日韩一区二区三区| 欧美一级播放| 日韩午夜精品| 玖玖综合伊人| 亚洲欧美电影院| 91久久久久久| 国产一区二区三区丝袜 | 久久久91精品| 亚洲乱码精品一二三四区日韩在线| 亚洲免费中文| 亚洲精品国产拍免费91在线| 国产精品日韩| 欧美日韩在线影院| 免费在线看成人av| 欧美一区二区成人| 中文日韩电影网站| 亚洲日本中文字幕| 91久久久国产精品| 亚洲成人影音| 伊人狠狠色丁香综合尤物| 国产在线国偷精品产拍免费yy| 欧美视频日韩视频在线观看| 久久久亚洲午夜电影| 久久久久久久精| 久久日韩粉嫩一区二区三区| 欧美在现视频| 久久婷婷影院| 欧美国产视频在线观看| 欧美精品久久久久久久久久| 免费视频最近日韩| 欧美va天堂在线| 欧美国产日韩精品| 亚洲精品乱码久久久久久日本蜜臀 | 欧美大学生性色视频| 久久视频在线看| 欧美国产日韩精品免费观看| 欧美伦理91i| 国产午夜精品一区二区三区欧美 | 亚洲第一精品夜夜躁人人躁 | 中文国产成人精品久久一| 亚洲人成人77777线观看| 亚洲精品社区| 国产精品99久久久久久有的能看| 亚洲在线一区二区| 久久在线免费| 国产精品系列在线| 亚洲国产一区二区a毛片| 久久亚洲一区| 欧美激情一区二区三区在线视频观看| 欧美精品97| 尤物99国产成人精品视频| 一区二区毛片| 欧美成人一区二区三区在线观看 | 亚洲美女中出| 久久精品视频在线| 国产精品伦子伦免费视频| 日韩视频国产视频| 欧美成人小视频| 久久aⅴ国产紧身牛仔裤| 欧美日韩亚洲国产一区| 亚洲激情影院| 欧美激情亚洲一区| 美女黄毛**国产精品啪啪| 国产午夜亚洲精品不卡| 亚洲资源av| 亚洲欧美在线看| 国产精品日韩欧美一区二区三区| 日韩视频久久| 亚洲视频大全| 国产精品自在欧美一区| 亚洲一区久久久| 亚洲欧美国产视频| 韩国在线一区| 亚洲国产成人精品久久| 欧美日韩国产综合新一区| 亚洲女ⅴideoshd黑人| 亚洲欧美国产va在线影院| 影视先锋久久| 99国产成+人+综合+亚洲欧美| 欧美日韩国产一区二区三区地区| 国产精品99久久99久久久二8 | 亚洲欧美区自拍先锋| 亚洲欧美成人| 亚洲电影免费在线观看| 亚洲国产精品第一区二区| 亚洲国产成人午夜在线一区| 欧美成人午夜激情在线| 亚洲欧美日韩国产成人| 久久精品国产一区二区电影| 精品成人国产| 亚洲高清久久| 亚洲啪啪91| 狠狠噜噜久久| 亚洲小说春色综合另类电影| 一区二区三区中文在线观看 | 国产亚洲午夜| 亚洲高清视频一区| 国产精品尤物福利片在线观看| 欧美成年视频| 在线观看欧美黄色| 亚洲欧美三级伦理| 亚洲一区二区免费看| 欧美大秀在线观看| 男同欧美伦乱| 一区二区在线视频| 久久频这里精品99香蕉| 久久er精品视频| 国产酒店精品激情| 亚洲伊人观看| 欧美影院久久久| 国产亚洲精品aa| 久久精品视频在线免费观看| 久久久精品免费视频| 韩国欧美国产1区| 久久久伊人欧美| 亚洲高清久久| 亚洲一区二区在线免费观看| 国产精品久久久久久久久免费桃花 | 国产精品专区一| 久久精品成人| 欧美高清不卡| 一区二区电影免费观看| 欧美视频不卡中文| 午夜精品一区二区在线观看| 欧美中文字幕| 99国产精品一区| 国产欧美精品日韩区二区麻豆天美| 亚洲一区二区三区成人在线视频精品| 欧美视频官网| 久久精品人人做人人爽| 国产精品magnet| 亚洲一区二区成人| 亚洲第一精品电影| 欧美在线免费视频| 99av国产精品欲麻豆| 国产在线视频不卡二| 欧美三级电影大全| 美女精品在线观看| 欧美亚洲免费| 亚洲小说欧美另类婷婷| 欧美肥婆在线| 老司机精品久久| 欧美自拍偷拍午夜视频| 午夜精品福利一区二区蜜股av| 最新精品在线| 亚洲黑丝在线| 亚洲国产小视频|