B - Shorten IPv6 Address

题意

给你\(128\)位的二进制,转换为十六进制。

每\(4\)位十六进制分为\(1\)组,每两组用一个\(“:”\)分开。

每一组的十六进制要去掉前导\(0\)。

如果存在连续两组以上的\(0\)要转换为\(“::”\)。比如,\(0:0:0、0:0\)都可以转换成\("::"\)。

但是最多只能转换一次,要求在长度最短的条件下字典序最小

思路

  1. 先把二进制串转换为16进制串
  2. 找到最长连续的\(0\)的位置转换为\(“::”\),如果长度相等,头和尾优先选尾,头和尾和中间,优先选中间。(长度相同,选中间会比选头或者尾短一个长度)

    三种不同的选法(明显中间最短,且最优)
 0:0:1:0:0:1:0:0
前:::1:0:0:1:0:0
后:0:0:1:0:0:1::
中:0:0:1::1:0:0

一些数据

1
00000000000000000000000000000000000000000000111100000000000000000000000000000000000000001111111100000000000000000000000000000000 Case #1: 0:0:f::ff:0:0

一些乱七八糟的感想

其实就是一个模拟啦,刚开始暴力选长度最长,相等全部给我往后走,然后就\(WA\)了, 作为一个专业划水选手,我就在旁边看着队友的代码一步步从\(50\)行到\(100\)行,到最后接近\(200\)行,三个人找不到错误,找到上面这个样例之后,发现还是\(WA\),最后还是用暴力找全部,然后找答案。看了题解之后发现好像没有其他的坑。嗯。。。吸取队友的经验,还是尝试写了一下代码,锻炼一下写代码的能力?,嗯。。。好像没有比赛的时候想的那么麻烦。嗯。。还是要努力呀,不能老是拖后腿呀。

AC 代码

#include<bits/stdc++.h>
using namespace std;
const int maxn = 200;
char ch[maxn];
int a[10][6];
int main(){
int T, Cas = 1;
scanf("%d", &T);
while(T--){
scanf("%s", ch+1);
int cnt = 0;
for(int i = 1; i <= 128;){
cnt++;
for(int k = 1; k <= 4; k++){ //每4个十六进制为1组
a[cnt][k] = 0;
for(int j = 3; j >= 0; j--,i++){ //每4位二进制转换一个十六进制
a[cnt][k] += (ch[i]-'0')*(1<<j);
}
}
}
int l, r, wl, wr; //变成::的位置
l = 1;r = 0;wl = 0, wr = -1;
for(int i = 1; i <= cnt; i++){
int flag = 0;
for(int j = 1; j <= 4; j++){
if(a[i][j] != 0){
flag = 1;
break;
}
}
if(!flag){ //当前为0
r++;
}
if(flag || i == cnt){ //当前不为0或者读到末尾
if(r-l+1 > wr-wl+1 && r-l+1 >= 2){
wl = l;wr = r;
}
else if(r-l+1 == wr-wl+1 && r-l+1 >= 2 && (r != cnt || wl == 1)){
wl = l;wr = r;
}
l = i+1;r = i;
}
}
printf("Case #%d: ", Cas++);
for(int i = 1; i <= cnt; i++){
if(i == wl){
if(i == 1)
printf(":");
printf(":");
if(wr == cnt)
printf("\n");
i = wr;
}
else{
int flag = 0;
for(int j = 1; j <= 4; j++){
char s = a[i][j] >= 10?a[i][j]-10+'a':a[i][j]+'0';
if(!flag && (a[i][j] != 0 || j == 4)){ //去前导0
flag = 1;
}
if(flag)
printf("%c", s);
}
printf("%c", i == cnt?'\n':':');
}
}
}
return 0;
}

2019牛客多校第六场 B - Shorten IPv6 Address 模拟的更多相关文章

  1. 2019 牛客多校第六场 B Shorten IPv6 Address

    题目链接:https://ac.nowcoder.com/acm/contest/886/B 题目大意 给定一个 128 位的二进制 ip 地址,让你以 16 位一组,每组转成 16 进制,用冒号连接 ...

  2. 牛客多校第六场 B Shorten IPv6 Address 模拟

    题意: 给你一个二进制表示的IPv6地址,让你把它转换成8组4位的16进制,用冒号分组的表示法.单组的前导0可以省略,连续多组为0的可以用两个冒号替换,但是只允许替换一次.把这个地址通过这几种省略方式 ...

  3. [题解]Shorten IPv6 Address-模拟(2019牛客多校第六场B题)

    题目链接:https://ac.nowcoder.com/acm/contest/886/B 题意: 您将获得一个IPv6地址,该地址是128位二进制字符串.请根据以下规则确定其最短的表示: 以十六进 ...

  4. 2019牛客多校第六场J-Upgrading Technology(枚举+单调队列)

    Upgrading Technology 题目传送门 解题思路 对于这题,我们可以枚举一个k从0~m,表示当前我们把所有技能最少升到了k级,且至少有一个为k级. 此时我们刚好获得了前k个d[]的收益, ...

  5. 2019 牛客多校第六场 D Move

    题目链接:https://ac.nowcoder.com/acm/contest/886/D 题解摘自官方题解 题目大意 有 K 个体积相同的箱子,有 N 个体积相同或相异的物品,现要按照如下策略装箱 ...

  6. 2019 牛客多校第六场 J Upgrading Technology

    题目链接:https://ac.nowcoder.com/acm/contest/886/J 题目大意 略. 分析 见代码. 代码如下 #include <bits/stdc++.h> u ...

  7. 2019牛客多校第六场H Pair(数位DP 多个数相关)题解

    题意: 传送门 给你\(A,B,C\),要求你给出有多少对\((x, y)\)满足\(x\in [1,A],y\in [1,B]\),且满足以下任意一个条件:\(x \& y > C\) ...

  8. 2019牛客多校第八场 F题 Flowers 计算几何+线段树

    2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...

  9. 牛客多校第六场 C Generation I 组合数学 阶乘逆元模板

    链接:https://www.nowcoder.com/acm/contest/144/C来源:牛客网 Oak is given N empty and non-repeatable sets whi ...

随机推荐

  1. Flask-SQLALchemy动态的filter_by和filter

    1.filter_by filter_by用于查询简单的列名,不支持比较运算符. filters = {'name': 'fengyao', 'age': 26} User.query.filter_ ...

  2. 【FICO系列】SAP FICO模块-固定资产月结的注意点

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[FICO系列]SAP FICO模块-固定资产月 ...

  3. 排序算法一:插入排序(Insertion sort)

    最近从网易公开课在看麻省理工学院的公开课<算法导论>,感觉还不错,接下来几篇文章所示学习日记了,不准备对算法细节做过多描述,感兴趣的可以自己去看. 文章分几篇讲经典排序算法,直接上代码,根 ...

  4. 异步请求jquery action

    package com.tarena.action; import java.util.HashMap;import java.util.Map; import javax.annotation.Re ...

  5. System的两常用个静态方法

    package cn.learn; /* System类在java.lang.System,和操作系统有关 1.currentTimeMillis直接调用,是一个返回为long型的静态方法 常用来计算 ...

  6. Python入门习题2.蟒蛇绘制(turtle库)

    例2.调用turtle库中的若干函数来绘制蟒蛇,要求:(1)主体窗口宽650像素,高度350像素,窗口左侧与屏幕左侧像素距离200,窗口顶部与屏幕顶部像素距离200:(2)画笔落点在原点反向前进250 ...

  7. NOI Day1T1归程(Kruskal重构树+Dijkstra)

    NOI Day1T1归程(Kruskal重构树+Dijkstra) 题目 洛谷题目传送门 题解 其实我不想写......,所以...... 挖个坑......我以后一定会补的 luogu的题解讲的还是 ...

  8. 【转】通俗理解Java序列化与反序列化

    一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存 ...

  9. ES6——解构赋值

    解构赋值: 注意: 1.左右两边结构必须一样 练习1,2,3 2.右边必须是个东西(有值)练习4 3.声明和赋值不能分开(必须在一句话里完成)练习5 /* 练习1: // let arr = [1,2 ...

  10. webpack中的图片打包之路

    最近在Github上弄项目,需要搭建一个webpack开发环境.Emmm,是的,从0开始搭建一个项目确实不容易,光Webpack的坑就够我踩一路的了.这不,刚搭建到“图片打包”这里,就遇到了麻烦.最后 ...