蓝桥杯 十六进制转八进制(超大测试数据,java实现)

问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

  【注意
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

拿到题目觉着还挺简单,直接用了String和Integer的几个函数,样例输出没问题。提交上去发现提示运行错误。

下载下来测试数据,才知道输入进去了一个多么变态的数:

 1 import java.util.Arrays;
 2 import java.util.Scanner;
 3
 4 public class Main {
 5
 6     public static void main(String[] args) {
 7         Scanner in=new Scanner(System.in);
 8         int n=in.nextInt();
 9         String [] result=new String[11];
10         for(int i=0;i<n;i++){
11                 String h=in.next();
12             String b=Integer.toBinaryString(Integer.valueOf(h, 16));
13             String o=Integer.toOctalString(Integer.valueOf(b, 2));
14             result[i]=o;
15         }
16         for(int i=0;i<n;i++){
17                 System.out.println(result[i]);
18         }
19     }
20 }
21     

第一次没有通过的代码

测试数据:

在第一次的代码上做了改动:

①首先将每一位十六进制数转换为四位二进制数(一定要转为4位,使用前导0),保存为字符串;

②将字符串长度化为3的倍数,以便向八进制转化;

③每三位转化为八进制,去掉前导零;

代码如下,可通过测试:

 1 import java.util.Arrays;
 2 import java.util.Scanner;
 3
 4 public class Poj {
 5
 6     public static void main(String[] args) {
 7         Scanner in=new Scanner(System.in);
 8         int n=in.nextInt();
 9         String [] result=new String[11];//保存最后输出的结果
10         /*十六进制转化为二进制*/
11         for(int i=0;i<n;i++){
12             String h=in.next();
13             StringBuilder tempB=new StringBuilder();
14             for(int m=0;m<h.length();m++){
15                 char numH=h.charAt(m);
16                 String b=Integer.toBinaryString(Integer.valueOf(String.valueOf(numH), 16));
17
18                 for(int k=b.length();k<4;k++){
19                     b=‘0‘+b;
20                 }
21
22                 tempB.append(b);
23             }
24
25             /*二进制转化为八进制*/
26             StringBuilder tempO=new StringBuilder();//长度变为3的倍数,需要补的前导0的个数
27             int addZero=3-tempB.length()%3;
28             for(int p=0;p<addZero;p++){
29                 tempB=new StringBuilder("0").append(tempB);
30             }
31             for(int m=0;m<tempB.length();m+=3){
32                 //把字符串长度转换为三的倍数添加前导0
33                 String numB=tempB.substring(m, m+3);
34                 String o=Integer.toOctalString(Integer.valueOf(String.valueOf(numB), 2));
35                 tempO.append(o);
36             }
37             result[i]=tempO.toString().replaceAll("^(0+)", "");//用正则表达式去掉前导零
38         }
39         for(int i=0;i<n;i++){
40             System.out.println(result[i]);
41         }
42     }
43 }
时间: 2024-08-08 05:36:45

蓝桥杯 十六进制转八进制(超大测试数据,java实现)的相关文章

算法笔记_208:第六届蓝桥杯软件类决赛真题(Java语言A组)

目录 1 胡同门牌号 2 四阶幻方 3 显示二叉树 4 穿越雷区 5 切开字符串 6 铺瓷砖   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 胡同门牌号 标题:胡同门牌号 小明家住在一条胡同里.胡同里的门牌号都是连续的正整数,由于历史原因,最小的号码并不是从1开始排的. 有一天小明突然发现了有趣的事情: 如果除去小明家不算,胡同里的其它门牌号加起来,刚好是100! 并且,小明家的门牌号刚好等于胡同里其它住户的个数! 请你根据这些信息,推算小明家的门牌号是多少? 请提交该整数,不要填写任何多

算法笔记_206:第五届蓝桥杯软件类决赛真题(Java语言A组)

目录 1 海盗分金币 2 六角幻方 3 格子放鸡蛋 4 排列序数 5 幂一矩阵 6 供水设施   1 海盗分金币 有5个海盗,相约进行一次帆船比赛. 比赛中天气发生突变,他们被冲散了. 恰巧,他们都先后经过途中的一个无名的荒岛,并且每个人都信心满满,觉得自己是第一个经过该岛的人. 第一个人在沙滩上发现了一堆金币.他把金币分成5等份.发现刚好少一个金币.他就从自己口袋拿出一个金币补充进去,然后把属于自己的那份拿走. 第二个到达的人也看到了金币,他也和第一个人一样,把所有金币5等分,发现刚好缺少一个

蓝桥杯 入门训练 Fibonacci数列(Java)

@Author : qingdujun 入门训练 Fibonacci数列  : http://lx.lanqiao.org/problem.page?gpid=T4 import java.util.Scanner; /** * 蓝桥杯: 入门训练 Fibonacci数列 * @author qingdujun * */ public class Main { public static void main(String[] args) { int f1 = 1; int f2 = 1; int

算法笔记_204:第四届蓝桥杯软件类决赛真题(Java语言C组)

目录 1 好好学习 2 埃及分数 3 金蝉素数 4 横向打印二叉树 5 危险系数 6 公式求值   1 好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的小朋友贴标语.他负责贴的标语是分别写在四块红纸上的四个大字:"好.好.学.习".但是汤姆不认识汉字,他就想胡乱地贴成一行. 请你替小汤姆算一下,他这样乱贴,恰好贴对的概率是多少? 答案是一个分数,请表示为两个整数比值的形式.例如:1/3 或 2/15 等. 如果能够约分,请输出约分后的结果. 注意:不要书写多余的空格. 请严格按照格式

算法笔记_202:第三届蓝桥杯软件类决赛真题(Java高职)

目录 1 填算式 2 提取子串 3 机器人行走 4 地址格式转换 5 排日程   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 填算式 [结果填空] (满分11分) 看这个算式: ☆☆☆ + ☆☆☆ = ☆☆☆ 如果每个五角星代表 1 ~ 9 的不同的数字. 这个算式有多少种可能的正确填写方法? 173 + 286 = 459 295 + 173 = 468 173 + 295 = 468 183 + 492 = 675 以上都是正确的填写法! 注意: 111 + 222 = 333 是错误

算法笔记_077:蓝桥杯练习 K好数(Java)

目录 1 问题描述 2 解决方案   1 问题描述 问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K进制数中K好数的数目.例如K = 4,L = 2的时候,所有K好数为11.13.20.22.30.31.33 共7个.由于这个数目很大,请你输出它对1000000007取模后的值. 输入格式 输入包含两个正整数,K和L. 输出格式 输出一个整数,表示答案对1000000007取模后的值. 样例输入 4 2 样例输出 7 数据规模与约定

算法笔记_063:蓝桥杯练习 送分啦(Java)

目录 1 问题描述 2 解决方案   1 问题描述 问题描述 这题想得分吗?想,请输出"yes":不想,请输出"no". 输出格式 输出包括一行,为"yes"或"no". 2 解决方案 初步一看,这题竟然没有输入输出示例,不过也不难吧.好吧,第一次,代码长这样: import java.util.Scanner; public class Main{ public static void main(String[] args)

算法笔记_123:蓝桥杯第七届省赛(Java语言B组部分习题)试题解答

 目录 1 凑算式 2 方格填数 3 四平方和   1 凑算式 凑算式 B DEF A + --- + ------- = 10 C GHI (如果显示有问题,可以参见[图1.jpg]) 这个算式中A~I代表1~9的数字,不同的字母代表不同的数字. 比如: 6+8/3+952/714 就是一种解法, 5+3/1+972/486 是另一种解法. 这个算式一共有多少种解法? 注意:你提交应该是个整数,不要填写任何多余的内容或说明性文字. (碰到除法问题,要特别注意,如题目未事先声明进行整除,均首先消

蓝桥杯:基础练习 杨辉三角形【JAVA算法实现】

题目描述 杨辉三角形又称Pascal三角形,它的第i+1行是(a+b)i的展开式的系数. 它的一个重要性质是:三角形中的每个数字等于它两肩上的数字相加. 下面给出了杨辉三角形的前4行: 1 1 1 1 2 1 1 3 3 1 给出n,输出它的前n行. 输入格式 输入包含一个数n. 输出格式 输出杨辉三角形的前n行.每一行从这一行的第一个数开始依次输出,中间使用一个空格分隔.请不要在前面输出多余的空格. 样例输入 4 样例输出 1 1 1 1 2 1 1 3 3 1 public class Ma