试题:一个字可由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;
}