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

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

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

代码:

#include <iostream>
#include <vector>
using namespace std; int ip[1005][5];
int yanma[55][5]; int M,N; int result[1005][5]; vector<int>xiangdeng; void yihuo(int count)
{
int i;
for(i=1;i<=M; i ++)
{
int j;
for(j=1;j<=4;j++)
{
result[i][j]=(ip[i][j]&yanma[count][j]);
}
}
} bool panduan(int a)
{
int count;
for(count=0;count<xiangdeng.size();count++)
{
if(xiangdeng[count]==a)
{
return false;
}
}
return true;
} void butong()
{
int i,j;
int result_real=0;
int neng[1005]; for(i=1;i<=1000;i++)
{
neng[i]=1;
} for(i=1;i<M;i++)
{
int m; if(neng[i]==1)
{
for(m=i+1;m<=M;m++)
{
int flag =1;
for(j=1;j<=4;j++)
{
if(result[i][j]!=result[m][j])
{
if(flag==1)
{
flag=0;
}
}
}
if(flag == 1)
{
neng[m]=0;
}
}
}
}
for(i=1;i<=M;i++)
{
if(neng[i])
result_real++;
}
cout<<result_real<<endl;
}
int main()
{
int count,countone;
cin>>count; for(countone=1;countone<=count;countone++)
{
cin>>M>>N; int count1;
for(count1=1;count1<=M;count1++)
{
int count2;
for(count2=1; count2<=4;count2++)
{
cin>>ip[count1][count2];
if(count2!=4)
{
char i;
cin>>i;
}
}
} for(count1=1;count1<=N;count1++)
{
int count2;
for(count2=1; count2<=4;count2++)
{
cin>>yanma[count1][count2];
if(count2!=4)
{
char i;
cin>>i;
}
}
}
cout<<"Case #"<<countone<<":"<<endl;
for(count1=1;count1<=N;count1++)
{
yihuo(count1);
butong();
}
} return 0;
}

看了其他人的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. 企业面试问题收集-ssh框架

    SSH框架阶段 SSH的优缺点,使用场景? Hibernate优缺点 Hibernate优点:(1) 对象/关系数据库映射(ORM)它使用时只需要操纵对象,使开发更对象化,抛弃了数据库中心的思想,完全 ...

  2. mysql innodb cluster 无感知集群

    MySQL 8.0.12 innodb cluster 高可用集群部署运维管理手册 Innodb cluster 原理介绍 Innodb cluster  利用组复制的 pxos 协议,保障数据一致性 ...

  3. uniGUI页面标题和页面背景的更改(03)

    ---------------------------------------------------------------------------------------------------- ...

  4. HTML中元素 标签 属性

    HTNL中元素是以开始标签开始 结束标签结尾的 如:<p>this is a paragraph </p> <p>是开始标签   </p>是结束标签  ...

  5. OPC DA通讯 KEP6.4 DCOM 配置脚本

    在OPC DA通讯测试时总是避免不了要配置DCOM,我习惯是在虚拟机中装这些通讯测试软件,每次安装都需要再次手动配置,感觉很是麻烦 因此,查找资料,了解到可以用dcomperm这个软件来在命令行下进行 ...

  6. 第2章 PLC1200 与HMI (TP900) 组合仿真连接 编写1200程序,编写HMI 仿真过程拍摄视频

    博途V13 与 WINCC PROFESSIONAL V13 创建一个PLC工程 和屏幕的 练习. 在做S1200与 HMI的仿真之前 需要设置控制面板 设置PG/PC口 巡视窗口用于看设备的一些属性 ...

  7. webpack 4 脚手架搭建

    1.在cmd控制台安装环境  npm install express (这是一个本地服务器配置) 2.在src 文件夹下建 mian.js 和 express.js 两个jS文件

  8. Fiddler抓取HTTPS

    对于想抓取HTTPS的测试初学者来说,常用的工具就是fiddler.可是在初学时,大家对于fiddler如何抓取HTTPS真是伤了脑筋,可能你一步步按着网上的帖子成功了,那当然是极好的. 有可能没有成 ...

  9. Eclipse - 常见问题 - Refresh

    有时候项目代码正确但运行后出现异常,是因为eclipse没有刷新 (如jar包添加了但没用),比较脑慢. 解决方法: clean缓存,或者要多点几次Refresh,或者重启 eclipse.

  10. Link Analysis_1_Basic Elements

    1. Edge Attributes 1.1 Methods of category 1.1.1 Basic three categories in terms of number of layers ...