描述

原理: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地址的特性,用位运算确实能让代码精简不少
当前帖子仅供自我精进、学习使用,有不足之处欢迎指正;