目录
描述
原理: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地址

解题过程
原先准备按照最笨的方法写,但是又觉得太繁琐。思路是定义一个长度为32的一维数组,分别将四个十进制数转换成二进制,然后分别存放在长度为8的数字串中。至于讲十进制数转换成IP地址,就用相反的过程实现。
提交代码
#include <stdio.h>
int main() {
int a,b,c,d;
unsigned int e;
scanf("%d.%d.%d.%d %u", &a,&b,&c,&d,&e);
printf("%u\n%d.%d.%d.%d",(a<<24)|(b<<16)|(c<<8)|d,e>>24,(e>>16)&255,(e>>8)&255,e&255);
return 0;
}
学习代码
(来源:https://www.nowcoder.com/users/741101912)
#include <stdio.h>
int main()
{
int a1,a2,a3,a4;
unsigned int b;
scanf("%d.%d.%d.%d %u", &a1,&a2,&a3,&a4,&b);
printf("%u\n%d.%d.%d.%d",
(a1<<24)|(a2<<16)|(a3<<8)|a4,
b>>24,(b>>16)&255,(b>>8)&255,b&255);
return 0;
}
使用的是位运算。位运算知识可参考:位运算详解_阿尔法豆的博客-CSDN博客_位运算;
收藏点
关于位运算
以下图片摘于上述链接:
60:111100;13:1101

博客介绍了如何将IP地址转换为整数和将整数转换回IP地址的方法,主要涉及位运算。通过将IP地址的每段转换为二进制并组合,然后转换为十进制数。同时,提供了解题思路和相关位运算知识的链接。

4935

被折叠的 条评论
为什么被折叠?



