题解 | 整数与IP地址间的转换

整数与IP地址间的转换

https://www.nowcoder.com/practice/66ca0e28f90c42a196afd78cc9c496ea

#include <iostream>
#include <string>
using namespace std;

unsigned int IPtoDD(string& s) {
    unsigned int ans = 0;//防止数值溢出
    size_t pos = 0;
    while (pos < s.length()) {
        size_t nextPos = s.find('.', pos); // 找到下一个点
        string part;
        if (nextPos == string::npos) {
            part = s.substr(pos); // 提取最后一个部分
        }
        else {
            part = s.substr(pos, nextPos - pos); // 提取当前部分
        }
        unsigned int num = stoul(part); // 将字符串转换为无符号整数
        ans = ans * 256 + num; // 更新结果
        if (nextPos == string::npos) {
            break; // 如果是最后一个部分,退出循环
        }
        pos = nextPos + 1; // 更新起始位置
    }
    return ans;
}

string DDtoIP(string& s) {
    unsigned long long dd = stoull(s); // 将字符串转换为无符号长整型,stoi函数转化的是int型,可能溢出
    string IP;
    unsigned long long power = 256 * 256 * 256; // 初始值为 256^3
    for (int i = 0; i < 4; i++) {
        if (i < 3) {
            IP += to_string(dd / power) + '.'; // 添加当前部分和点
        }
        else {
            IP += to_string(dd / power); // 最后一个部分不加点
        }
        dd = dd % power; // 更新剩余部分
        power = power / 256; // 更新 power
    }
    return IP;
}

int main() {
    string s1, s2;
    cin >> s1;
    cin >> s2;
    if (s1.find('.') != string::npos) { // 判断是否为 IP 地址
        unsigned int DD = IPtoDD(s1);
        cout << DD << endl;
    }
    else { // 否则为十进制数
        string IP = DDtoIP(s1);
        cout << IP << endl;
    }

    if (s2.find('.') != string::npos) { // 判断是否为 IP 地址
        int DD = IPtoDD(s2);
        cout << DD << endl;
    }
    else { // 否则为十进制数
        string IP = DDtoIP(s2);
        cout << IP << endl;
    }

    return 0;
}

这是一个非常笨的办法,作为一个没有太多项目经验的学生,我居然忘记了移位操作这么简单的东西,笑死。

我的想法很简单,IP地址被“.”分割开的每一个部分,其实都可以看作进制为256的数的一位,可以采用简单粗暴的进制转换的数学方法去做,只是要注意int型数据可能会超范围,这也是我找了半天bug才发现的,同时,在数字转化为IP地址的过程中,记得加上“.”就好。

全部评论

相关推荐

08-06 13:59
吉首大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务