阅读以下技术说明、流程图和C程序,根据要求回答问题1和问题2。【说明】如图6-13所示的程序流程图描述了对8位二进制整数求补的算法。该算法的计算过程如下:从二进制数的低位(最右位)开始,依次向高位逐位查看,直到首次遇到“1”时,停止查看。然后,对该“1”位左面的更高位(如果存在的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10010110求补的结果时01101010。设8位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的BIT[1]~BIT[8]中。例如,二进制整数10010110存放在数组BIT后,则有BIT[1]=0,BIT[2]=1,…,BIT[7]=0,BIT[8]=1。若流程图中存在空操作,则用NOP表示。以下待修改的【C程序】完成的功能是:对于给定的1个长正整数,从其个位数开始,每隔一位取1个数字(即取其个位、百位和万位等数字),形成1个新的整数并输出。例如,将该程序修改正确后,运行时若输入“9753186420”,则输出的整数为“73840”。【C程序】行号 C代码01 include <stdio.h>02 int main()03 { long n,num;04 int i;05 do {06 printf("请输入一个正整数:");07 scanf("%1d",n);08 }while(n<=0);09 k = 1;10 for (i=1;n>=0;i++) {11 if (i%2=1) {12 num = num + (n%10)*k;13 k = k*10;14 }15 n = n/10;16 }17 printf("新数据为:%d\n",num);18 return 0;19 }请将图6-13流程图中(1)~(5)空缺处的内容补充完整。其中,(1)空缺处按“循环变量名:循环初值,增量,循环终值”格式描述。

阅读以下技术说明、流程图和C程序,根据要求回答问题1和问题2。

【说明】

如图6-13所示的程序流程图描述了对8位二进制整数求补的算法。该算法的计算过程如下:从二进制数的低位(最右位)开始,依次向高位逐位查看,直到首次遇到“1”时,停止查看。然后,对该“1”位左面的更高位(如果存在的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10010110求补的结果时01101010。

设8位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的BIT[1]~BIT[8]中。例如,二进制整数10010110存放在数组BIT后,则有BIT[1]=0,BIT[2]=1,…,BIT[7]=0,BIT[8]=1。若流程图中存在空操作,则用NOP表示。

以下待修改的【C程序】完成的功能是:对于给定的1个长正整数,从其个位数开始,每隔一位取1个数字(即取其个位、百位和万位等数字),形成1个新的整数并输出。例如,将该程序修改正确后,运行时若输入“9753186420”,则输出的整数为“73840”。

【C程序】

行号 C代码

01 include <stdio.h>

02 int main()

03 { long n,num;

04 int i;

05 do {

06 printf("请输入一个正整数:");

07 scanf("%1d",n);

08 }while(n<=0);

09 k = 1;

10 for (i=1;n>=0;i++) {

11 if (i%2=1) {

12 num = num + (n%10)*k;

13 k = k*10;

14 }

15 n = n/10;

16 }

17 printf("新数据为:%d\n",num);

18 return 0;

19 }

请将图6-13流程图中(1)~(5)空缺处的内容补充完整。其中,(1)空缺处按“循环变量名:循环初值,增量,循环终值”格式描述。


相关考题:

一个不带符号的二进制数,如何求其补码?() A.补码等于其二进制数原码B.二进制数原码逐位求反C.二进制数反码最低有效位加1D.二进制数低位(包括小数部分)的第一个“1”右边保持不变(包括此1),左边依次求反

阅读下列说明和流程图2-3,将应填入(n)的字句写在答题纸的对应栏内。【说明】下面的流程图描述了对8位二进制整数求补的算法。该算法的计算过程如下:从二进制数的低位(最右位)开始,依次向高位逐位查看,直到首次遇到“1”时,停止查看。然后,对该“1”位左面的更高位(如果有的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10101000求补的结果是01011000。设8位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的B1T[1]~BIT[8]中。例如,二进制整数10101000存放在数组BIT后,就有BIT[1]=0,BIT[2]=0,…,BIT[7] =0,BIT[8]=1。若流程图中存在空操作,则用NOP表示。【流程图】注:流程图中(1)处按“循环变量名:循环初值,增量,循环终值”格式描述。

阅读以下说明和流程图,回答问题1和问题2。【说明】设8位二进制代码B0B1…B7中的最高位B0为奇偶校验位。对于任何给定的代码B1B2…B7,可按下式计算偶校验位:其中,“”表示“异或”运算。下面的流程图描述了计算偶校验位的过程。【流程图】注:流程图中,循环开始的说明按照“循环变量名:循环初值,循环终值,增量”格式描述。将流程图中的(1)~(4)处补充完整。

阅读下列说明和流程图,将应填入(n)的语句写在对应栏内。【流程图】下面的流程图描述了对16位二进制整数求补的算法。计算过程是:从二进制数的低位 (最右位)开始,依次向高位逐位查看,直到首次遇到“1”时,停止查看。然后,对该“1”位左面的更高位(如果有的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10111001 10101000求补的结果是01000110 01011000。设16位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的BIT[1]~BIT[16]中。例如,二进制整数10111001 10101000存放在数组BIT后,就有BIT1[1]=0, BIT[2]=0,……,BIT[15]=0,BIT[16]=1。流程图(如图1所示)中(1)处按“循环变量名:循环初值,增量,循环终值”格式描述。若流程图中存在空操作,则用NOP表示。

阅读以下说明和C函数将应填入(n)处的字句写在答题纸的对应栏内【说明1】函数Counter(intn,intw[])的功能是计算整数n的二进制表示形式中的1个数同时用数组w记录该二进制数中1所在位置的权。例如十进制数22的二进制表示为10110.对于该二进制数,1的个数为3,在w[0]中存入2(即21)、w[1]中存入4(即22)w[2]存入16(即24)【C函数1】

阅读以下说明和流程图,回答问题1~2,将解答填入答题纸对应的解答栏内。[说明]给定一个十进制整数A,将其转换为R进制数的方法是:将A的整数部分逐次除以R,直到商等于0为止,将所得的余数由低位到高位排列在一起,就得到了对应R的进制数。以A=11,R=2为例,11÷2=5…1,5÷2=2…1,2÷2=1…0,1÷2=0…1中各式的余数依次为:1,1,0,1,于是与A对应的二进制数为1011。下面的流程图实现了将十进制数2597转换为八进制数的功能,其中:(1)循环1执行除法运算并将余数依次记录在数组a中(假定数组长度足够长),如a[1], a[2],……,a[k];(2)循环2则用于将这些余数按逆序输出,即a[k],a[k-1],……,a[1];(3)图中i,j分别是循环1和循环2中的循环变量;(4)图中q用于记录每次除法所得的商值。[流程图][问题1]将流程图中的(1)~(4)处补充完整,其中(1)~(3)处要求使用C语言格式书写:(1)处为逻辑表达式,(2)、(3)两处为算术表达式;(4)则须按照“循环变量名:循环初值,循环终值,增量”格式描述。[问题2]该算法运行的结果(5)。

图7-5所示的流程图描述了对8位二进制整数求补的算法。该算法的计算过程如下:从二进制数的低位(最右位)开始,依次向高位逐位查看,直到首次遇到“1”时,停止查看。然后,对该“1”位左面的更高位(如果有的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10101000求补的结果是01011000。设8位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的BIT[1]~BIT[8]中。例如,二进制整数10101000存放在数组BIT后,就有BIT[1]=0, BIT[2]=0, …, BIT[7]=0, BIT[8]=1。若流程图中存在空操作,则用NOP表示。流程图中(1)处按“循环变量名:循环初值,增量,循环终值”格式描述。[解析] 本题考查求补运算。求补运算是对一个数的各二进制位按位求反后再加1。例如:二进制10101000按位求反后得到的二进制是01010111,加1后为01011000。也可以这样来看,原二进制从最右边开始到遇到的第1个1为止都不变,而后面剩下的位按位求反即可。本题流程图采用的是后一种思路,首先设置一个标志sw的值为0,从最右边一位开始往左循环遍历整个二进制数,到遇到第1个1后将标志位置1。由此可见,循环要进行8次,循环变量值依次从1递增到8。根据题目要求按“循环变量名:循环初值,增量,循环终值”格式描述循环,而循环开始下面一条判断是“BIT[i]=1?”,所以循环变量是i,第1空应填i:1,1,8。如果当前遍历的二进制位BIT[i]是1,且标志sw为0时,则证明是第1次遇到1,所以直接设置sw为1即可,故第2空应填1→sw。如果当前遍历的二进制位BIT[i]是1,且标志sw为1时,说明已经不是第1次遇到1了,所以直接设置当前二进制位为0即可,故第3空应填0→BIT[i]。如果当前遍历的二进制位BIT[i]是0,且标志sw为0时,则证明还没有遇到过一次1,所以该步什么都不用做,故第4空应填NOP。如果当前遍历的二进制位BIT[i]是0,且标志sw为1时,说明已经遇到过1了,所以该步需将当前的二进制位求反,故第5空应填1→BIT[i]。

关于基本ASCII码,在计算机中的表示方法准确地描述是______ A、使用8位二进制数,最右边一位为1B、 使用8位二进制数,最左边一位为1C、使用8位二进制数,最右边一位为0D、使用8位二进制数,最左边一位为0

关于基本ASCII码在计算机中的表示方法,准确的描述应是()。 A.使用8位二进制数,最右边一位为1B.使用8位二进制数,最左边一位为1C.使用8位二进制数,最右边一位为0D.使用8位二进制数,最左边一位为0

字符的ASCII码在机器中的表示方法准确地描述应是:使用()。 A.8位二进制代码,最右1位为0B.8位二进制代码,最左1位为1C.8位二进制代码,最左1位为0D.8位二进制代码,最右1位为1

●试题一阅读下列说明和流程图,将应填入(n)的语句写在答题纸的对应栏内。【流程图】图1下面的流程图描述了对16位二进制整数求补的算法。计算过程是:从二进制数的低位(最右位)开始,依次向高位逐位查看,直到首次遇到"1"时,停止查看。然后,对该"1"位左面的更高位(如果有的话),逐位求反,所得的结果就是对原二进制数求补的结果。例如:对二进制整数10111001 10101000求补的结果是01000110 01011000。设16位二进制整数中的各位,从低位到高位,依次存放在整型数组BIT的BIT[1]~BIT[16]中。例如,二进制整数10111001 10101000存放在数组BIT后,就有BIT1[1]=0,BIT[2]=0,……,BIT[15]=0,BIT[16]=1。流程图(如图1所示)中 (1) 处按"循环变量名:循环初值,增量,循环终值"格式描述。若流程图中存在空操作,则用NOP表示。

字符的ASCII编码在计算机中的表示方法描述准确的是()。 A.8位二进制代码,最右1位为1B.8位二进制代码,最右1位为0C.8位二进制代码,最左1位为1D.8位二进制代码,最左1位为0

计算机中每个二进制数据位只能存放0或1,则8个二进制位组成的数转换成十进制整数后,不可能的是()A0B255C256D127

字符的ASCII编码在计算机中的表示方法描述准确的是()。A、8位二进制代码,最右1位为1B、8位二进制代码,最右1位为0C、8位二进制代码,最左1位为1D、8位二进制代码,最左1位为0

移位和按位运算符有哪些作用?()A、 左移“〈〈”可将整数乘以2或者2的若干次方B、 按位与“”可设置二进制数的某些位为0C、 按位或“”可将两个二进制数相加D、 按位异或“^”可将二进制数的某些位或者所有位设为相反的值E、 无符号右移“”可将整数除以2或者2的若干次方

下列各机器数所表示数的范围是多少? (1)8位二进制无符号定点整数 (2)8位二进制无符号定点小数 (3)16位二进制无符号定点整数 (4)用补码表示的16位二进制有符号整数

设无符号二进制整数X有n位,各位上的数字均为“1”,则X=()。A、2n-1-1B、2n-1C、2n

用八位二进制表示无符号的整数,则能表示数的范围是从0到()

将下列十进制数转换成8位二进制补码整数。 (1)-12 (2)-101 (3)56 (4)142

关于基本ASCII码在计算机中的表示方法,准确的描述应是()。A、使用8位二进制数,最右边一位为1B、使用8位二进制数,最左边一位为1C、使用8位二进制数,最右边一位为0D、使用8位二进制数,最左边一位为0

下面关于二进制数常用单位的描述,正确的有()A、Bit(位)是数据的最小单位,即二进制数的1位B、Byte(字节)是基本存储单位,对应8位二进制位C、worD(字)是整体参与运算和处理的一组二进制数D、字长是“字”的二进制数的位数,不固定

单选题设无符号二进制整数X有n位,各位上的数字均为“1”,则X=()。A2n-1-1B2n-1C2n

单选题字符的ASCII码在机器中的表示方法准确地描述应是:使用()。A8位二进制代码,最右1位为0B8位二进制代码,最左1位为1C8位二进制代码,最左1位为0D8位二进制代码,最右1位为1

单选题字符的ASCII编码在计算机中的表示方法描述准确的是()。A8位二进制代码,最右1位为1B8位二进制代码,最右1位为0C8位二进制代码,最左1位为1D8位二进制代码,最左1位为0

单选题如果对某模拟信号进行采样后,有256个量化级别,则()。A用位7bit来表示结果B用1个字节来表示结果C用256位二进制数来表示结果D用128位二进制数来表示结果

填空题若要将一个8位二进制整数的最高位和最低位清零,其他位不变,可以将该数和二进制数()进行“与”运算

单选题如果对某模拟信号进行采样后,有256个量化级别,则()。A用位7bit来表示结果B用1个字节来表示结果C用256位二进制数来表示结果D用128位二进制数来表示