描述
原理:ip地址的每段可以看成是一个0-255的整数,把每段拆分成一个二进制形式组合起来,然后把这个二进制数转变成
一个长整数。
举例:一个ip地址为10.0.3.193
每段数字 相对应的二进制数
10 00001010
0 00000000
3 00000011
193 11000001
组合起来即为:00001010 00000000 00000011 11000001,转换为10进制数就是:167773121,即该IP地址转换后的数字就是它了。
数据范围:保证输入的是合法的 IP 序列
输入描述:
输入
1 输入IP地址
2 输入10进制型的IP地址
输出描述:
输出
1 输出转换成10进制的IP地址
2 输出转换后的IP地址
示例1
输入:
10.0.3.193 167969729
输出:
167773121 10.3.3.193
#include <stdio.h> //以下是Senky的代码: void start(){ int a,b,c,d;//第一次输入ip地址的四个字段 int ip_to_binary=0;//ip转换成序列的二进制 int num;//第二次输入ip地址转换后的序列十进制 int ip[4];//序列十进制转换成ip,暂存在ip[]中 while(~scanf("%d.%d.%d.%d", &a, &b, &c, &d)){//读取一个ip地址 scanf("%u",&num);//读取一个转换后的序列 ip_to_binary=((a<<24)|(b<<16)|(c<<8)|d); printf("%u\n",ip_to_binary);//无符号输出ip_to_binary就是序列 //把序列转换成ip: ip[0]=(num&0xff000000)>>24; ip[1]=(num&0x00ff0000)>>16; ip[2]=(num&0x0000ff00)>>8; ip[3]=(num&0x000000ff); printf("%d.%d.%d.%d\n",ip[0], ip[1], ip[2], ip[3]); } } int main() { start(); return 0;//编辑于2022/10/14 }
总结:
①由于ip地址的特性,用位运算确实能让代码精简不少;
②当前帖子仅供自我精进、学习使用,有不足之处欢迎指正;