Преобразование int в двоичное представление строки в Java?

168

Каков наилучший способ (в идеале, самый простой) для преобразования int в двоичное строковое представление в Java?

Например, допустим, что int равно 156. Двоичное строковое представление этого будет «10011100».

Тайлер Лечить
источник

Ответы:

330
Integer.toBinaryString(int i)
разъем
источник
Это удобно! Есть ли подобный метод для длинных?
Тайлер Лечить
46
@ ttreat31: Я не хочу сказать, что это звучит странно, но вы действительно должны иметь под рукой документацию (в данном случае JavaDoc), когда вы программируете. Вы не должны спрашивать: является ли это похожим методом для длинных; вам нужно его посмотреть, чем напечатать комментарий.
Лоуренс Дол
5
@ Джек, есть ли способ получить двоичную строку в фиксированном количестве битов, например, десятичный 8 в 8-
битном
38

Существует также метод java.lang.Integer.toString (int i, int base) , который был бы более уместным, если бы ваш код мог когда-нибудь обрабатывать базы, отличные от 2 (двоичные).

izilotti
источник
26
public static string intToBinary(int n)
{
    string s = "";
    while (n > 0)
    {
        s =  ( (n % 2 ) == 0 ? "0" : "1") +s;
        n = n / 2;
    }
    return s;
}
Ариэль Бадилья
источник
20

Еще один способ - используя java.lang.Integer, вы можете получить строковое представление первого аргумента iв radix (Octal - 8, Hex - 16, Binary - 2)указанном вторым аргументом.

 Integer.toString(i, radix)

Пример_

private void getStrtingRadix() {
        // TODO Auto-generated method stub
         /* returns the string representation of the 
          unsigned integer in concern radix*/
         System.out.println("Binary eqivalent of 100 = " + Integer.toString(100, 2));
         System.out.println("Octal eqivalent of 100 = " + Integer.toString(100, 8));
         System.out.println("Decimal eqivalent of 100 = " + Integer.toString(100, 10));
         System.out.println("Hexadecimal eqivalent of 100 = " + Integer.toString(100, 16));
    }

Вывод_

Binary eqivalent of 100 = 1100100
Octal eqivalent of 100 = 144
Decimal eqivalent of 100 = 100
Hexadecimal eqivalent of 100 = 64
Рупеш Ядав
источник
5
public class Main  {

   public static String toBinary(int n, int l ) throws Exception {
       double pow =  Math.pow(2, l);
       StringBuilder binary = new StringBuilder();
        if ( pow < n ) {
            throw new Exception("The length must be big from number ");
        }
       int shift = l- 1;
       for (; shift >= 0 ; shift--) {
           int bit = (n >> shift) & 1;
           if (bit == 1) {
               binary.append("1");
           } else {
               binary.append("0");
           }
       }
       return binary.toString();
   }

    public static void main(String[] args) throws Exception {
        System.out.println(" binary = " + toBinary(7, 4));
        System.out.println(" binary = " + Integer.toString(7,2));
    }
}
Артавазд Манукян
источник
Результаты бинарные = 0111 бинарные = 111
Артавазд Манукян
1
String hexString = String.format ("% 2s", Integer.toHexString (h)). Replace ('', '0');
Артавазд Манукян
5

Это то, что я написал несколько минут назад, просто бездельничал. Надеюсь, поможет!

public class Main {

public static void main(String[] args) {

    ArrayList<Integer> powers = new ArrayList<Integer>();
    ArrayList<Integer> binaryStore = new ArrayList<Integer>();

    powers.add(128);
    powers.add(64);
    powers.add(32);
    powers.add(16);
    powers.add(8);
    powers.add(4);
    powers.add(2);
    powers.add(1);

    Scanner sc = new Scanner(System.in);
    System.out.println("Welcome to Paden9000 binary converter. Please enter an integer you wish to convert: ");
    int input = sc.nextInt();
    int printableInput = input;

    for (int i : powers) {
        if (input < i) {
            binaryStore.add(0);     
        } else {
            input = input - i;
            binaryStore.add(1);             
        }           
    }

    String newString= binaryStore.toString();
    String finalOutput = newString.replace("[", "")
            .replace(" ", "")
            .replace("]", "")
            .replace(",", "");

    System.out.println("Integer value: " + printableInput + "\nBinary value: " + finalOutput);
    sc.close();
}   

}

AbbyPaden
источник
5

Преобразовать целое число в двоичное:

import java.util.Scanner;

public class IntegerToBinary {

    public static void main(String[] args) {

        Scanner input = new Scanner( System.in );

        System.out.println("Enter Integer: ");
        String integerString =input.nextLine();

        System.out.println("Binary Number: "+Integer.toBinaryString(Integer.parseInt(integerString)));
    }

}

Вывод:

Введите целое число:

10

Двоичный номер: 1010

Sidarth
источник
Чрезмерное продвижение определенного продукта / ресурса (который я здесь удалил) может восприниматься сообществом как спам . Взгляните на справочный центр , в частности, какое поведение ожидается от пользователей? Последний раздел: Избегайте явной саморекламы . Вы также можете быть заинтересованы в Как разместить рекламу на переполнение стека? ,
Тунаки
4

Используя встроенную функцию:

String binaryNum = Integer.toBinaryString(int num);

Если вы не хотите использовать встроенную функцию для преобразования int в двоичный файл, вы также можете сделать это:

import java.util.*;
public class IntToBinary {
    public static void main(String[] args) {
        Scanner d = new Scanner(System.in);
        int n;
        n = d.nextInt();
        StringBuilder sb = new StringBuilder();
        while(n > 0){
        int r = n%2;
        sb.append(r);
        n = n/2;
        }
        System.out.println(sb.reverse());        
    }
}
Рачит Шривастава
источник
4

Самый простой подход - проверить, не является ли число нечетным. Если это, по определению, его крайнее правое двоичное число будет «1» (2 ^ 0). После того как мы определили это, мы немного сдвигаем число вправо и проверяем то же значение с помощью рекурсии.

@Test
public void shouldPrintBinary() {
    StringBuilder sb = new StringBuilder();
    convert(1234, sb);
}

private void convert(int n, StringBuilder sb) {

    if (n > 0) {
        sb.append(n % 2);
        convert(n >> 1, sb);
    } else {
        System.out.println(sb.reverse().toString());
    }
}
wild_nothing
источник
1
Я думаю, это действительно элегантный способ сделать это вручную, если вы действительно не хотите использовать встроенные методы.
praneetloke
4

вот мои методы, это немного убедительно, что число байтов фиксировано

private void printByte(int value) {
String currentBinary = Integer.toBinaryString(256 + value);
System.out.println(currentBinary.substring(currentBinary.length() - 8));
}

public int binaryToInteger(String binary) {
char[] numbers = binary.toCharArray();
int result = 0;
for(int i=numbers.length - 1; i>=0; i--)
  if(numbers[i]=='1')
    result += Math.pow(2, (numbers.length-i - 1));
return result;
}
Алексей Тимощенко
источник
3

Использование битового сдвига немного быстрее ...

public static String convertDecimalToBinary(int N) {

    StringBuilder binary = new StringBuilder(32);

    while (N > 0 ) {
        binary.append( N % 2 );
        N >>= 1;
     }

    return binary.reverse().toString();

}
Эдди Б
источник
2

Это может быть выражено в псевдокоде как:

while(n > 0):
    remainder = n%2;
    n = n/2;
    Insert remainder to front of a list or push onto a stack

Print list or stack
amoljdv06
источник
1

Вы должны действительно использовать Integer.toBinaryString () (как показано выше), но если по какой-то причине вы хотите свой собственный:

// Like Integer.toBinaryString, but always returns 32 chars
public static String asBitString(int value) {
  final char[] buf = new char[32];
  for (int i = 31; i >= 0; i--) {
    buf[31 - i] = ((1 << i) & value) == 0 ? '0' : '1';
  }
  return new String(buf);
}
overthink
источник
0

Это должно быть довольно просто с чем-то вроде этого:

public static String toBinary(int number){
    StringBuilder sb = new StringBuilder();

    if(number == 0)
        return "0";
    while(number>=1){
        sb.append(number%2);
        number = number / 2;
    }

    return sb.reverse().toString();

}
Сандип Сайни
источник
0

Вы можете также использовать цикл while для преобразования int в двоичный файл. Как это,

import java.util.Scanner;

public class IntegerToBinary
{
   public static void main(String[] args)
   {
      int num;
      String str = "";
      Scanner sc = new Scanner(System.in);
      System.out.print("Please enter the a number : ");
      num = sc.nextInt();
      while(num > 0)
      {
         int y = num % 2;
         str = y + str;
         num = num / 2;
      }
      System.out.println("The binary conversion is : " + str);
      sc.close();
   }
}

Источник и ссылка - конвертировать int в двоичный файл в примере с Java .

Шива
источник
0
public class BinaryConverter {

    public static String binaryConverter(int number) {
        String binary = "";
        if (number == 1){
            binary = "1";
            System.out.print(binary);
            return binary;
        }
        if (number == 0){
            binary = "0";
            System.out.print(binary);
            return binary;
        }
        if (number > 1) {
            String i = Integer.toString(number % 2);

            binary = binary + i;
            binaryConverter(number/2);
        }
        System.out.print(binary);
        return binary;
    }
}
Ахмед Сака
источник