题解 | 整数与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地址的过程中,记得加上“.”就好。