Convert.ToString
może służyć do konwersji liczby na jej równoważną reprezentację w postaci ciągu w określonej bazie.
Przykład:
string binary = Convert.ToString(5, 2); // convert 5 to its binary representation
Console.WriteLine(binary); // prints 101
Jednak, jak wskazano w komentarzach, Convert.ToString
obsługuje tylko następujący ograniczony - ale zazwyczaj wystarczający - zestaw podstaw: 2, 8, 10 lub 16.
Aktualizacja (aby spełnić wymóg konwersji na dowolną bazę):
Nie znam żadnej metody w BCL, która jest w stanie przekonwertować liczby na dowolną bazę, więc musiałbyś napisać własną małą funkcję użytkową. Prosty przykład wyglądałby tak (zauważ, że z pewnością można to zrobić szybciej, zastępując konkatenację ciągów):
class Program
{
static void Main(string[] args)
{
// convert to binary
string binary = IntToString(42, new char[] { '0', '1' });
// convert to hexadecimal
string hex = IntToString(42,
new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
'A', 'B', 'C', 'D', 'E', 'F'});
// convert to hexavigesimal (base 26, A-Z)
string hexavigesimal = IntToString(42,
Enumerable.Range('A', 26).Select(x => (char)x).ToArray());
// convert to sexagesimal
string xx = IntToString(42,
new char[] { '0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x'});
}
public static string IntToString(int value, char[] baseChars)
{
string result = string.Empty;
int targetBase = baseChars.Length;
do
{
result = baseChars[value % targetBase] + result;
value = value / targetBase;
}
while (value > 0);
return result;
}
/// <summary>
/// An optimized method using an array as buffer instead of
/// string concatenation. This is faster for return values having
/// a length > 1.
/// </summary>
public static string IntToStringFast(int value, char[] baseChars)
{
// 32 is the worst cast buffer size for base 2 and int.MaxValue
int i = 32;
char[] buffer = new char[i];
int targetBase= baseChars.Length;
do
{
buffer[--i] = baseChars[value % targetBase];
value = value / targetBase;
}
while (value > 0);
char[] result = new char[32 - i];
Array.Copy(buffer, i, result, 0, 32 - i);
return new string(result);
}
}
Aktualizacja 2 (poprawa wydajności)
Użycie buforu tablicy zamiast konkatenacji ciągów do skompilowania ciągu wynikowego zapewnia poprawę wydajności, szczególnie w przypadku dużej liczby (patrz metoda IntToStringFast
). W najlepszym przypadku (tj. Najdłuższym możliwym wejściu) ta metoda jest mniej więcej trzy razy szybsza. Jednak dla liczb 1-cyfrowych (czyli 1-cyfrowych w bazie docelowej), IntToString
będzie szybszy.