网站大量收购独家精品文档,联系QQ:2885784924

RIP路由算法通信实例.doc

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
RIP路由算法通信实例

RIP路由算法通信实例 //MY_RIP_TextA.cpp #include stdio.h #include stdlib.h #include winsock2.h #pragma comment(lib, ws2_32.lib) #define SEND_LENGTH 5000 #define RECV_LENGTH 5000 #define A 4 #define B 6 typedef struct route_info{ int intent_net; int distance; int next_route; struct route_info* next; }ROUTE_INFO; int menu(); void init_route(ROUTE_INFO* head); int update_route(ROUTE_INFO* head); void select_route(ROUTE_INFO* head); void free_linked_list(ROUTE_INFO* head); void route_to_char(ROUTE_INFO* head,char route_infor[]); void char_to_route(ROUTE_INFO* head,char route_infor[]); void RIP_algorithm(ROUTE_INFO* head,ROUTE_INFO* recv); void main() { int menu_value; ROUTE_INFO* head; head = (ROUTE_INFO*)malloc(sizeof(ROUTE_INFO)); head-next_route=A; head-next=NULL; while(1) { menu_value = menu(); switch(menu_value) { case 1: init_route(head); break; case 2: update_route(head); break; case 3: select_route(head); break; case 4: exit(0); break; default: printf(输入菜单选项有误,请重新输入.); break; } } free_linked_list(head); } int menu() { int i=0; printf(***************路由器R4***************\n); printf(** 1.录入初始路有路由信息。 **\n); printf(** 2.更新路由信息。 **\n); printf(** 3.查询路由信息。 **\n); printf(** 4.exit。 **\n); printf(**************************************\n); scanf(%d,i); return i; } void init_route(ROUTE_INFO* head) { ROUTE_INFO* route_info; ROUTE_INFO* p=head; char c; while(1) { route_info = (ROUTE_INFO*)malloc(sizeof(ROUTE_INFO)); p-next=route_info; p=p-next; p-next=NULL; printf(请输入目的网络、距离、下一跳路由器:); scanf(%d,p-intent_net); scanf(%d,p-distance); scanf(%d,p-next_route); scanf(%c,c); printf(是否继续y/n:); scanf(%c,c); if(c==y||c==Y); else if(c==n||c==N) break; /* printf(%d ,p-intent_net); printf(%d ,p-distance); printf(%d \n,p-next_route);*/ } } int update_route(ROUTE_INFO* head) { WORD socketVersi

文档评论(0)

mg60065 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档