十进制转二进制java
时间: 2023-11-12 19:58:09 浏览: 63
好的,以下是将十进制转换为二进制的Java代码:
```java
public static String decimalToBinary(int decimal) {
String binary = "";
while (decimal > 0) {
int remainder = decimal % 2;
binary = remainder + binary;
decimal = decimal / 2;
}
return binary;
}
```
这个方法接受一个十进制数作为参数,并返回一个字符串,表示该数的二进制表示形式。它使用了一个 while 循环来不断地将十进制数除以 2,直到商为 0。在每次循环中,它计算余数并将其添加到二进制字符串的开头。
例如,如果你调用 `decimalToBinary(13)`,它将返回字符串 `"1101"`,因为十进制数 13 的二进制表示形式是 1101。
相关问题
栈十进制转二进制 java
以下是使用Java中的栈将十进制转换为二进制的代码示例:
```java
import java.util.Scanner;
import java.util.Stack;
public class Main {
public static void main(String[] args) {
Stack<Integer> stack = new Stack<Integer>();
Scanner scan = new Scanner(System.in);
int N = scan.nextInt();
while(N > 0){
int m = N % 2;
stack.push(m);
N /= 2;
}
while(!stack.isEmpty()){
System.out.print(stack.pop());
}
}
}
```
这段代码首先创建了一个整型栈和一个Scanner对象,然后从用户输入中读取一个十进制数N。接下来,使用while循环将N转换为二进制数并将每一位数字压入栈中。最后,使用另一个while循环将栈中的数字弹出并输出,即可得到N的二进制表示。
java 十进制转二进制
有多种方法可以在Java中将十进制数转换为二进制数。一种方法是使用Integer类的toString()方法,该方法接受两个参数:要转换的十进制数和基数。对于将十进制转换为二进制,我们可以将基数设置为2。下面是一个示例程序:
```java
import java.util.Scanner;
public class JavaD2B {
public static void main(String[] args) {
int number;
Scanner sc = new Scanner(System.in);
System.out.println("Enter a decimal number: ");
number = sc.nextInt();
System.out.println("Binary number is " + Integer.toString(number, 2));
}
}
```
另一种方法是使用Integer类的toBinaryString()方法,该方法直接将十进制数转换为二进制数。下面是一个示例程序:
```java
import java.util.Scanner;
public class JavaD2B {
public static void main(String[] args) {
int number;
Scanner sc = new Scanner(System.in);
System.out.println("Enter a decimal number: ");
number = sc.nextInt();
System.out.println("Binary number is " + Integer.toBinaryString(number));
}
}
```
如果你想了解更多关于十进制转二进制的方法,可以参考下面的示例程序。这个程序使用了辗转相除法来实现转换:
```java
import java.util.Scanner;
public class Number2Binary {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
while (true) {
System.out.print("Input a number: ");
int number = input.nextInt();
int number2;
// 如果是负数,需要加上2^31次方
if (number < 0) {
number2 = (int) (Math.pow(2, 31) + number);
} else {
number2 = number;
}
String binary = "";
// 通过辗转相除法,求出二进制数,保存在binary中
int shang = number2;
int yu;
int count = 0;
while (shang != 0) {
yu = shang % 2;
shang /= 2;
count++;
if (count % 4 == 0) {
binary = "_" + yu + binary;
} else {
binary = yu + binary;
}
}
// 不够32位,需要补齐
while (count < 31) {
count++;
if (count % 4 == 0) {
binary = "_" + 0 + binary;
} else {
binary = 0 + binary;
}
}
// 判断符号位
if (number < 0) {
binary = 1 + binary;
} else {
binary = 0 + binary;
}
System.out.println(binary);
}
}
}
```