我有一个函数,它接受一个数字,并将其转换为5x7的图形表示,如下所示:
Console.WriteLine(" ███ "); // byte: 0000 1110
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine(" ███ "); // 0000 1110
我被告知使用字节数组可以更快地完成。这就是我所做的:
byte[] data = new byte[] { 14, 17, 17, 17, 17, 17, 14 };
BitArray bitData = new BitArray(data);
int bitCounter = 0;
foreach (bool bit in bitData)
{
if (bit)
Console.Write("█");
else
Console.Write(" ");
bitCounter++;
if (bitCounter>7)
{
bitCounter=0;
Console.WriteLine();
}
}
这比开始的慢,所以我不能使用它。谁能告诉我更好的方法?
更新:StringBuilder确实有帮助,但它会比我原来的代码慢一点。它基本上仍然在控制台上使用7次写命令,这减慢了我的速度。我尝试使用使用只使用1写入命令使用n,但我需要缩进下一行而不擦除缩进的空间内。
I最小化IO。下面是一个版本,只在最后进行控制台调用。
var stringBuilder = new StringBuilder();
bitCounter = 0;
foreach (bool bit in bitData)
{
if (bit)
stringBuilder.Append("█");
else
stringBuilder.Append(" ");
bitCounter++;
if (bitCounter > 7)
{
bitCounter = 0;
Console.WriteLine(stringBuilder.ToString());
stringBuilder.Clear();
}
}