透明网桥的自学习算法

该博客介绍了一个透明网桥的自学习算法,通过读取输入的源地址和目的地址,判断数据包在不同网段间的转发路径。程序使用C语言编写,涉及到源地址查找、目的地址匹配以及根据匹配结果决定数据包的转发方向,包括向左、向右转发或丢弃。同时,程序还展示了网桥1和网桥2的当前记录状态。
摘要由CSDN通过智能技术生成
#include<stdio.h>
void main()
{
    char arr1[3]={'A','B','C'};
    char arr2[2]={'D','E'};
    char arr3[3]={'F','G','H'};
    int a[][2]={0,0,0,0,0,0,0,0,0,0,0,0};
    int b[][2]={0,0,0,0,0,0,0,0,0,0,0,0};
    int i,j,m,n,k1 = 0,k2 = 0,t; 
    char s,d,k;
    
    while(1)
    {
        printf("请输入源地址和目的地址:");
        scanf("%c%c",&s,&d);
        printf("\n");
        for(i=0;i<3;i++){
            if(arr1[i]==s)
                m=1;
        }
        for(i=0;i<2;i++){
            if(arr2[i]==s)
                m=2;
        }
        for(i=0;i<3;i++){
            if(arr3[i]==s)
                m=3;
        }
        switch(m)
        {
        case 1:
            {
                for(i=0;i<k1;i++){
                    if(a[i][0]==s)
                    {break;}
                }
                if(i==k1) {a[k1][0]=s;a[k1][1]=m;k1++;}//没有记录,在网桥数组中插入源地址
                
                for(i=0;i<k1;i++)//查找网桥数组中是否有目的地址
                {
                    if(a[i][0]==d)
   
  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值