杭电oj —— 2051(十进制转二进制 Java有自带转换)

package com.demo2;
import java.util.Scanner;
/*
 * Give you a number on base ten,you should output it on base two.(0 < n < 1000)
 */
public class HDU_oj2051 {
	public static void main(String[] args) {
		Scanner sn = new Scanner(System.in);
		while(sn.hasNext()) {
			int n = sn.nextInt(); //十进制,将其转化为二进制
			System.out.println(compute(n));
		}
		sn.close();
	}
	public static String compute(int num) {
		int n = num;
		StringBuffer sb = new StringBuffer();
		while(n != 0) {
			int temp =n % 2; //模2 得到的是最后一位数
			sb.append(temp);
			n = n/2; //除以基数
		}
		return sb.reverse().toString();
	}
}
package com.demo2;

import java.util.Scanner;

public class HUD_oj2051_1 {
	public static void main(String[] args) {
		Scanner sn = new Scanner(System.in);
		while(sn.hasNext()) {
			int n = sn.nextInt(); //十进制,将其转化为二进制
			System.out.println(Integer.toBinaryString(n));
		}
		sn.close();
	}
}

 

将八进制数转换二进制数可以通过直接的映射关系来实现。因为每一位八进制数字可以表示为3位二进制数,所以只需将每一位八进制数字分别转换为对应的3位二进制数,然后按顺序拼接即可。 ### 八进制到二进制转换方法 1. 将输入的八进制数按位拆分。 2. 每一位八进制数字转换为3位的二进制数,例如: - 0 → `000` - 1 → `001` - 2 → `010` - 3 → `011` - 4 → `100` - 5 → `101` - 6 → `110` - 7 → `111` 3. 将所有转换后的二进制数依次拼接,得到最终的二进制结果。 ### Python实现示例 以下是一个Python代码示例,用于将八进制数转换二进制数: ```python def octal_to_binary(oct_num): # 定义八进制到二进制的映射字典 oct_to_bin = { '0': '000', '1': '001', '2': '010', '3': '011', '4': '100', '5': '101', '6': '110', '7': '111' } # 转换每位八进制数字为3位二进制数 bin_result = ''.join([oct_to_bin[digit] for digit in str(oct_num)]) return bin_result # 输入一个八进制数 oct_input = input("请输入一个八进制数:") binary_output = octal_to_binary(oct_input) print(f"{oct_input} 的二进制表示为:{binary_output}") ``` ### C语言实现示例 在C语言中,也可以通过类似的逻辑实现八进制到二进制转换。以下是使用数组和字符串处理的实现方式: ```c #include <stdio.h> #include <string.h> void octal_to_binary(char *oct_str, char *bin_str) { // 定义八进制到二进制的映射表 const char *oct_map[] = { "000", "001", "010", "011", "100", "101", "110", "111" }; bin_str[0] = '\0'; // 初始化目标字符串为空 for (int i = 0; i < strlen(oct_str); i++) { char digit = oct_str[i]; if (digit >= '0' && digit <= '7') { strcat(bin_str, oct_map[digit - '0']); } else { printf("无效的八进制数字:%c\n", digit); break; } } } int main() { char oct_input[32], bin_output[128]; printf("请输入一个八进制数:"); scanf("%s", oct_input); octal_to_binary(oct_input, bin_output); printf("%s 的二进制表示为:%s\n", oct_input, bin_output); return 0; } ``` 上述代码通过逐字符查找映射表的方式实现了八进制到二进制转换[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值