zoukankan      html  css  js  c++  java
  • 十进制转十六进制

    题目描述:

    十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。
    给出一个非负整数,将它表示成十六进制的形式。

    输入:

    输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647

    输出:

    输出这个整数的16进制表示

    例样输入:

    30

    例样输出:

    1E

    解题思路:

    十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,由此可用String的CharAt()来获取指定索引处的值。十六进制表示0~9,'A'、'B'、'C'、'D'、'E'、'F',余数大于9

    可先创建一个String的方法,用来反转字符串,再创建一个方法遍历

    代码:

    package Demo01;
    import java.util.Scanner;
    public class demo01 {
    public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    int n = sc.nextInt();
    System.out.println(Xiang(n));
    }
    //反转字符串
    public static String Li(String s){
    int length=s.length();
    String r = "";
    for(int i=length-1;i>=0;i--){
    r += s.charAt(i);//charAt(int)表示返回char指定索引处的值
    }
    return r;
    }
    //遍历
    public static String Xiang(int n){
    String s = "";
    while(n > 0){
    int chenk = n % 16;
    if(chenk >9){//余数大于9,
    char c=(char)(chenk-10+'A');//强转为字符型
    s += c;
    }else{
    s += chenk;
    }
    n = n / 16;
    }
    return Li(s);//调用反转字符串函数
    }
    }

  • 相关阅读:
    Search Insert Position(二分查找)
    c++基础题
    Divide Two Integers(模拟计算机除法)
    Swap Nodes in Pairs(链表操作)
    Letter Combinations of a Phone Number(带for循环的DFS,组合问题,递归总结)
    进程和程序的区别
    Add Two Numbers(链表)
    Longest Substring Without Repeating Characters
    02.友盟项目--原始日志数据生成
    01.友盟项目--nginx服务器配置
  • 原文地址:https://www.cnblogs.com/lixiang0622/p/13403060.html
Copyright © 2011-2022 走看看