汉子点阵/明码

试题:一个字可由NN的灯来表示,事实上跟像素的原理一样,只不过这处用点阵来形容更为贴切,一个字可由1616来表示,十进制数字4就可以表示为00000100,一行由两个十进制数字组成,也就是(4,0)为0000010000000000。
(1)补全程序(空白处需要填写内容不止一行)
(2)将主程序的十个数字替换掉,最后显现的汉字应为答题者名字的最后一个字。

解:这里的试题来源是 第九届蓝桥杯试题–明码,这里由其改编而成,并且难度降低了,没有要求去求补码。 思路就是,将所给数据转换成二进制数(简单在于,不用考虑负数,遇到直接将其全部置1,而仅仅只对0及正整数转换)。 然后将为二进制中为1的情况打印为指定字符即可。

#include<stdio.h>
void pre_change(int n)
{
    
    
	char a[9] = "        ";
	int i = 8;
	while (i > 0)
	{
    
    
		i--;
		if (n < 0)
		{
    
    
			a[i] = 'x';
		}
		if (n > 0)
		{
    
    
			(n%2==0)?(a[i]=' '):a[i]='x';
			n/=2;
		}
	}
	printf("%s", a);
}
void change(int n, int m)
{
    
    
	pre_change(n);
	pre_change(m);
	printf("\n");
}

int main()
{
    
    
	change(4, 96);
	change(4, 48);
	change(4, 24);
	change(4, 0);
	change(-1, -1);
	change(4, 128);
	change(4, 128);
	change(4, 128);
	change(4, 140);
	change(4, 152);
	change(8, 176);
	change(8, 224);
	change(16, 194);
	change(17, 130);
	change(38, 126);
	change(64, 0);
	return 0;
}

猜你喜欢

转载自blog.csdn.net/Aurora____/article/details/107047358