UVa 1590 - IP Networks
2015-01-04 23:22
375 查看
当初被这道题吓到了,其实是个水题。。。懒的写函数了,直接各种循环。
#include<iostream> #include<cstring> #include<cstdio> #define MAXN 1010 using namespace std; int main() { // freopen("in.txt", "r", stdin); int m, p[5], n = 0, d = 1 << 8; char ip[MAXN][8 * 4 + 10], final_ip[32]; while(cin >> m) { memset(p, 0, sizeof(0)); memset(ip, 0, sizeof(0)); memset(final_ip, 0, sizeof(0)); int max_len = 32; for(int i = 1; i <= m; i++) { scanf("%d.%d.%d.%d", &p[1], &p[2], &p[3], &p[4]); ip[i][32] = '\0'; for(int j = 31; j >= 0; j--) { ip[i][j] = p[j / 8 + 1] % 2; p[j / 8 + 1] /= 2; } } for(int i = 1; i < m; i++) for(int j = i + 1; j <= m; j++) for(int k = 0; k < 32; k++) if(ip[i][k] != ip[j][k]) { if(k < max_len) max_len = k; break; } for(int i = max_len; i < 32; i++) ip[1][i] = 0; for(int i = 0; i < 32; i++) i < max_len ? final_ip[i] = 1 : final_ip[i] = 0; for(int i = 0; i < 32; i++) { d /= 2; n += ip[1][i] * d; if(d == 1) { cout << n; n = 0; d <<= 8; if(i != 31) cout << "."; } } cout << endl; for(int i = 0; i < 32; i++) { d /= 2; n += final_ip[i] * d; if(d == 1) { cout << n; n = 0; d <<= 8; if(i != 31) cout << "."; } } cout << endl; } return 0; }
相关文章推荐
- UVa 1590 IP Networks(IP 网络)
- 算法竞赛入门经典 第二版 习题4-5 IP网络 IP Networks uva1590
- UVa 1590 IP Networks
- Uva 1590 IP Networks
- UVa 1590 - IP Networks(进制转换+细节处理)
- UVA - 1590 IP Networks
- Uva 1590 IP Networks
- UVA 1590 IP Networks(IP 网络)
- 小紫书 4-5 UVA 1590 IP Networks
- UVA 1590 IP Networks
- UVA 1590 - IP Networks
- UVA 1590 - IP Networks
- UVA 1590 IP Networks
- UVA 1590 IP Networks(暴力)
- UVALive3520 UVa1590 POJ2799 IP Networks【进制+位运算】
- UVA1590 IP网络(IP Networks)
- Uva 1590 IP Networks
- UVA 1590 IP Networks
- UVA 1590 IP Networks
- Uva-1590 - IP Networks-AC