算法描述如下:自学习:当网桥收到一转发帧时,先查找自己的转发表中是否有源地址,若没有则添加此项。转发帧:查找自己转发表中是否有目的地址,若没有则将此帧从其他端口转发出去。若有,则将转发表中记录的目的地址端口和此帧进入网桥时通过的端口进行比较,若相等则丢弃此帧(因为目的主机已经收到此帧了),若不相等,则将此帧通过转发表记录的目的地址端口转发出去。源码如下:(此代码在突出算法思想的情况下设计的尽量简单,有的情况没有考虑,或者简单处理了。)12#include3usingnamespacestd;4#defineMax_Data100//转发表数据项数量5structData//数据项结构6{7charAdd;//地址8intport;//端口9};10structSendTable//转发表结构11{12Datadata[Max_Data];13intwrite;//写指针,指向下一个要写的位置14}sendTable;15voidinitSendTable()16{17for(inti=0;i>source>>port;62sourceData.Add=source;63sourceData.port=port;64cout<<"InputdestinationAddress:\\n";65cin>>destination;66destinationData.Add=destination;67destinationData.port=0;//由于目的地址不需要输入端口号,此处将其置068if(!Find(sourceData))//查找转发表,若找不到则将源地址添加如转发表69AddSendTable(sourceData);70if(!Find(destinationData))//查找转发表,若找不到则将此帧从所有其他端口发送给别的网桥71cout<<"SendthisDatatootherbridgethroughotherport\\n";72else73{74if(sendTable.data[index].port==sourceData.port)//若收到此帧的端口和目的地址再转发表存储的端口相同,说明源地址和目的地址处在同一网段内,目的主机已经收到此帧,须将其丢弃75cout<<"ThisDataalreadyreceived,sogiveitup.\\n";76else//若端口不同,则通过查找到的端口将此帧发出77cout<<"SendthisDatathroughport"<2voidmain()3{4chararr1[3]={'A','B','C'};5chararr2[2]={'D','E'};6chararr3[3]={'F','G','H'};7inta[][2]={0,0,0,0,0,0,0,0,0,0,0,0};8intb[][2]={0,0,0,0,0,0,0,0,0,0,0,0};9inti,j,m,n,k1=0,k2=0,t;10chars,d,k;1112while(1)13{14printf("请输入源地址和目的地址:");15scanf("%c%c",&s,&d);16printf("\n");17for(i=0;i<3;i++){18if(arr1[i]==s)19m=1;20}21for(i=0;i<2;i++){22if(arr2[i]==s)23m=2;24}25for(i=0;i<3;i++){26if(arr3[i]==s)27m=3;28}29switch(m)30{31case1:32{33for(i=0;i