部分进制间的转换

简介: 部分进制间的转换

文章目录


十进制转换为十六进制

十六进制转换为十进制

十六进制转八进制的三种方法


十进制转换为十六进制


import java.util.Scanner;
public class Main {
  public static void main(String[] args) {
    Scanner src=new Scanner(System.in);
    long n=src.nextLong();
    String arry=Long.toHexString(n);
    arry=arry.toUpperCase();
    System.out.println(arry);   
  }
}

十六进制转换为十进制


import java.util.Scanner; 
public class t14 {
  public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    String string = scanner.nextLine();
      System.out.println(Long.valueOf(string,16));    //方法一
      System.out.println(Long.parseLong(string, 16));  //方法二
  }
}

十六进制转八进制的三种方法


import java.util.Arrays;
import java.util.Scanner;
 class Main {
  //第一种方法就是用Integer.parseInt(a,b); 
  //接收字符串a然后以b进制去接受它
  //再用Integer.toString(a, b)把a从十进制转换成b进制的数字
//  public static void main(String[] args) {
//    Scanner sc =new Scanner(System.in);
//    int n = sc.nextInt();
//    for (int i = 0; i <n; i++) {
//      String a = sc.next();
//      int b = Integer.parseInt(a,16);
//    //  System.out.println(b);
//      String ss =Integer.toString(b, 8);
//      System.out.println(ss);
//    }
//  }
  //第二种方法就是Integer类自带的二进制,八进制,十六进制
  //Integer.valueOf(a, b)这个的用法和上面那个parseInt一样
//    public static void main(String[] args) {
//          Scanner in=new Scanner(System.in);
//          int n=in.nextInt();
//          String [] result=new String[11];
//          for(int i=0;i<n;i++){
//                  String h=in.next();
//              String b=Integer.toBinaryString(Integer.valueOf(h, 16));
//              String o=Integer.toOctalString(Integer.valueOf(b, 2));
//              result[i]=o;
//          }
//          for(int i=0;i<n;i++){
//                  System.out.println(result[i]);
//          }
//      }
  //第三种就是比较传统的自己写出各种进制的表,这里就要用到二进制和八进制的关系了
  //这里大概说一下,如果想继续钻研的可以自己百度一下
  //因为是这里最高是16进制每一个二进制的里面都对着一个16进制的数字
  //因为正好2的4次方是16进制,2进制的四位数正好把每一个四进制的数都一一对应着
  //取得时候直接按照相等的值取就可以了
  //这道题就是先把16进制转换成二进制,再按照对应的方法取八进制对应的值
  public static void main(String[] args) {
    // 接受输入 n
    Scanner scanner = new Scanner(System.in);
    String input_n = scanner.nextLine();
    int n = Integer.parseInt(input_n);
    // 接受输入十六进制数的字符串
    String[] input_nums = new String[n];
    for (int i = 0; i < n; i++) {
      input_nums[i] = scanner.nextLine();
    }
    scanner.close();
    // 十六进制表
    String[] HEXs = { 
      "0", "1", "2", "3", "4", "5", "6", "7", 
      "8", "9", "A", "B", "C", "D", "E", "F"
    };
    // 二进制表
    String[] BINs = { 
      "0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", 
      "1000", "1001", "1010", "1011", "1100", "1101", "1110", "1111" 
    };
    // 八进制表
    String[] OCTs = { 
      "0", "1", "2", "3", "4", "5", "6", "7"
    };
    // 十六进制表和二进制表,在所有成员上值一一对应
    // 十六进制表、二进制表和八进制表,在前八位成员上值一一对应
    for (int m = 0; m < n; m++) { // 遍历每个十六进制数字
      String hex = input_nums[m]; // 十六进制表示形式
      StringBuffer sbBin = new StringBuffer();
      StringBuffer sbOct = new StringBuffer();
      // 十六进制转二进制
      // 将十六进制数每一位转换成四位的二进制数字
      for (int i = 0; i < hex.length(); i++) { // 遍历每个十六进制位
        String c = Character.toString(hex.charAt(i));
        // 查询当前位字符在 HEXs中的下标
        int index = Arrays.binarySearch(HEXs, c);
        sbBin.append(BINs[index]);
      }
      // 在二进制数前面插入若干个"0",使得二进数的位数为 3 的倍数
      while (sbBin.length() % 3 != 0) {
        sbBin.insert(0, "0");
      }
      int octLen = sbBin.length() / 3; // 计算目标八进制数的长度
      // 每次取三位二进制数,转换成对应的八进制
      for (int i = 0; i < octLen; i++) {
        String span = sbBin.substring(3 * i, 3 * i + 3);
        int index = Arrays.binarySearch(BINs, "0" + span);
        sbOct.append(OCTs[index]);
      }
      // 此时已经得到结果,需要去除前导 0
      while (sbOct.charAt(0) == '0') {
        sbOct.delete(0, 1);
      }
      System.out.println(sbOct.toString());
    }
  }
}


相关文章
关于优化Vue-router优化import引入过多导致index文件过于臃肿
关于优化Vue-router优化import引入过多导致index文件过于臃肿
143 1
|
10天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
9天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
410 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
3天前
|
存储 安全 前端开发
如何将加密和解密函数应用到实际项目中?
如何将加密和解密函数应用到实际项目中?
199 138
|
9天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
379 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
|
3天前
|
存储 JSON 安全
加密和解密函数的具体实现代码
加密和解密函数的具体实现代码
197 136
|
21天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1355 8
|
8天前
|
监控 JavaScript Java
基于大模型技术的反欺诈知识问答系统
随着互联网与金融科技发展,网络欺诈频发,构建高效反欺诈平台成为迫切需求。本文基于Java、Vue.js、Spring Boot与MySQL技术,设计实现集欺诈识别、宣传教育、用户互动于一体的反欺诈系统,提升公众防范意识,助力企业合规与用户权益保护。