保持着也不知道什么情怀,觉得到现在才能发出来。这道题做完之后看了其他人的代码,然后再看我的,不得不说,真是幼稚的很,尤其是输入这一块,都什么跟什么啊。

但相较于之前来说,不像以前慌张了,学会先思考再去写代码,明白了函数的一些用处与含义。我知道一个大四的老狗说这种话倒还真是够没面子的,但希望自己每天都在成长。你眼里的小草,我心中的大树。

IP聚合

Problem Description

当今世界,网络已经无处不在了,小度熊由于犯了错误,当上了度度公司的网络管理员,他手上有大量的 IP列表,小度熊想知道在某个固定的子网掩码下,有多少个网络地址。网络地址等于子网掩码与
IP 地址按位进行与运算后的结果,例如:

子网掩码:A.B.C.D

IP 地址:a.b.c.d

网络地址:(A&a).(B&b).(C&c).(D&d)

Input

第一行包含一个整数T,(1≤T≤50)代表测试数据的组数,

接下来T组测试数据。每组测试数据包含若干行,

第一行两个正整数N(1≤N≤1000,1≤M≤50),M。接下来N行,每行一个字符串,代表一个
IP 地址,

再接下来M行,每行一个字符串代表子网掩码。IP
地址和子网掩码均采用 A.B.C.D的形式,其中ABCD均为非负整数,且小于等于255。

Output

对于每组测试数据,输出两行:

第一行输出:"Case #i:"
i代表第i组测试数据。

第二行输出测试数据的结果,对于每组数据中的每一个子网掩码,输出在此子网掩码下的网络地址的数量。

Sample Input

2

5 2

192.168.1.0

192.168.1.101

192.168.2.5

192.168.2.7

202.14.27.235

255.255.255.0

255.255.0.0

4 2

127.127.0.1

10.134.52.0

127.0.10.1

10.134.0.2

235.235.0.0

1.57.16.0

Sample Output

Case #1:

3

2

Case #2:

3

4

代码:

  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;
  4.  
  5. int ip[1005][5];
  6. int yanma[55][5];
  7.  
  8. int M,N;
  9.  
  10. int result[1005][5];
  11.  
  12. vector<int>xiangdeng;
  13.  
  14. void yihuo(int count)
  15. {
  16. int i;
  17. for(i=1;i<=M; i ++)
  18. {
  19. int j;
  20. for(j=1;j<=4;j++)
  21. {
  22. result[i][j]=(ip[i][j]&yanma[count][j]);
  23. }
  24. }
  25. }
  26.  
  27. bool panduan(int a)
  28. {
  29. int count;
  30. for(count=0;count<xiangdeng.size();count++)
  31. {
  32. if(xiangdeng[count]==a)
  33. {
  34. return false;
  35. }
  36. }
  37. return true;
  38. }
  39.  
  40. void butong()
  41. {
  42. int i,j;
  43. int result_real=0;
  44. int neng[1005];
  45.  
  46. for(i=1;i<=1000;i++)
  47. {
  48. neng[i]=1;
  49. }
  50.  
  51. for(i=1;i<M;i++)
  52. {
  53. int m;
  54.  
  55. if(neng[i]==1)
  56. {
  57. for(m=i+1;m<=M;m++)
  58. {
  59. int flag =1;
  60. for(j=1;j<=4;j++)
  61. {
  62. if(result[i][j]!=result[m][j])
  63. {
  64. if(flag==1)
  65. {
  66. flag=0;
  67. }
  68. }
  69. }
  70. if(flag == 1)
  71. {
  72. neng[m]=0;
  73. }
  74. }
  75. }
  76. }
  77. for(i=1;i<=M;i++)
  78. {
  79. if(neng[i])
  80. result_real++;
  81. }
  82. cout<<result_real<<endl;
  83. }
  84. int main()
  85. {
  86. int count,countone;
  87. cin>>count;
  88.  
  89. for(countone=1;countone<=count;countone++)
  90. {
  91. cin>>M>>N;
  92.  
  93. int count1;
  94. for(count1=1;count1<=M;count1++)
  95. {
  96. int count2;
  97. for(count2=1; count2<=4;count2++)
  98. {
  99. cin>>ip[count1][count2];
  100. if(count2!=4)
  101. {
  102. char i;
  103. cin>>i;
  104. }
  105. }
  106. }
  107.  
  108. for(count1=1;count1<=N;count1++)
  109. {
  110. int count2;
  111. for(count2=1; count2<=4;count2++)
  112. {
  113. cin>>yanma[count1][count2];
  114. if(count2!=4)
  115. {
  116. char i;
  117. cin>>i;
  118. }
  119. }
  120. }
  121. cout<<"Case #"<<countone<<":"<<endl;
  122. for(count1=1;count1<=N;count1++)
  123. {
  124. yihuo(count1);
  125. butong();
  126. }
  127. }
  128.  
  129. return 0;
  130. }

看了其他人的AC代码,首先你看人家的输入scanf(“%d.%d.%d.%d”),另外一点就是完全可以把IP地址弄成一个数去比较,<<8  <<16 <<24即可。而不用像我一直在想如何在多个数组中找,太麻烦了。

最后的感受就是一种思路不行的时候,换一个别的可能就会OK。一开始只想找差别,各种wrong。最后的想法是找相同的,统计不同的就行了。

但总之,这是我第一次比赛中的AC,不管题多简单,自己做得又是有多麻烦,希望这是起点。

版权声明:本文为博主原创文章,未经博主允许不得转载。

[百度之星]资格赛:IP聚合的更多相关文章

  1. 百度之星资格赛--IP聚合

    IP聚合 Accepts: 1901 Submissions: 4979 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/6553 ...

  2. 2015百度之星之-IP聚合

    IP聚合  Accepts: 138  Submissions: 293  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: 6553 ...

  3. 【百度之星】-IP聚合

    问题描述: Problem Description 当今世界,网络已经无处不在了,小度熊由于犯了错误,当上了度度公司的网络管理员,他手上有大量的 IP列表,小度熊想知道在某个固定的子网掩码下,有多少个 ...

  4. 模拟 2015百度之星资格赛 1003 IP聚合

    题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...

  5. 模拟 百度之星资格赛 1003 IP聚合

    题目传送门 /* 模拟水题,排序后找出重复的ip就可以了 */ #include <cstdio> #include <iostream> #include <algor ...

  6. 2016百度之星 资格赛ABCDE

    看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...

  7. HDU 5688:2016"百度之星" - 资格赛 Problem D

    原文链接:https://www.dreamwings.cn/hdu5688/2650.html Problem D Time Limit: 2000/1000 MS (Java/Others)    ...

  8. HDU 5686:2016"百度之星" - 资格赛 Problem B

    原文链接:https://www.dreamwings.cn/hdu5686/2645.html Problem B Time Limit: 2000/1000 MS (Java/Others)    ...

  9. HDU 5685:2016"百度之星" - 资格赛 Problem A

    原文链接:https://www.dreamwings.cn/hdu5685/2637.html Problem A Time Limit: 2000/1000 MS (Java/Others)    ...

  10. 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)

    .navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...

随机推荐

  1. task20160125

    http://task.zbj.com/2034844/n15o1.html 百度开放平台--首页>帮助文档首页>Frontia>Android开发指南>个人数据存储 http ...

  2. 4.使用Redis+Flask维护动态代理池

    1.为什么使用代理池 许多⽹网站有专⻔门的反爬⾍虫措施,可能遇到封IP等问题. 互联⽹网上公开了了⼤大量量免费代理理,利利⽤用好资源. 通过定时的检测维护同样可以得到多个可⽤用代理理. 2.代理池的要 ...

  3. Centos7 nginx 反向代理的配置

    一.正向代理与反向代理 1.正向代理 正向代理往VPN理解 正向代理,也就是传说中的代理,他的工作原理就像一个跳板(VPN),简单的说: 我是一个用户,我访问不了某网站,但是我能访问一个代理服务器,这 ...

  4. C/C++网络编程1——linux下实现

    网络编程就是编写程序使两台联网的计算机相互交换数据. 例子:服务器端开启一个socket,监听9999端口.客户端向服务器端发起请求,服务器端收到请求以后,给客户端发送一句:"hello w ...

  5. LeetCode刷题--26.删除排序数组中的重复项(简单)

    题目描述 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度.不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(1)额外空间的条件下完成. 示例 ...

  6. http-equiv属性的属性值X-UA-Compatible

    参考:https://blog.csdn.net/changjiangbuxi/article/details/26054755

  7. TP-Link TL-WR841N v14 CVE-2019-17147 缓冲区溢出漏洞分析笔记v2018.12.31

    0x00 背景 Httpd服务中的缓冲区溢出漏洞 复现参考文章https://www.4hou.com/posts/gQG9 Binwalk -Me 解压缩 File ./bin/busybox文件类 ...

  8. Js 获取当前日期时间及其它操作(转)

    Js获取当前日期时间及其它操作 var myDate = new Date();myDate.getYear();        //获取当前年份(2位)myDate.getFullYear();   ...

  9. CSP-S2019 爆炸记

    DAY -1 停课的第五天.早上来机房教练居然不在,先看了一道憨题,发现ST表+二分查找nlogn水过,然后发现单调栈可以O(n),肥肠开心 打了走人. 然后就开始颓了(逃 颓了一会之后看愤怒的小鸟这 ...

  10. java核心-多线程(6)-线程池-ThreadPoolExecutor

    1.java多线程编程少不了使用线程池,线程池相关的工具类所在jdk包,java.util.concurrent 2.使用示例 demo1 public class ThreadPoolDemo { ...