十进制数

DNA图谱 / 问答 / 标签

ASCII码怎么和十进制数互相转换

1)ASCII码转十进制即按二进制转十进制方法,按权展开求和。[1]例:0110110b转十进制=0*2^6+1*2^5+1*2^4+0*2^3+1*2^2+1*2^1+0*2^0=542)十进制整数转二进制数:“除以2取余,逆序排列”(除二取余法)[1]ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统。[2]参考:[1]http://baike.baidu.com/link?url=5sKVI3mxz5cafbS1j2U-t-R_zp--7lcVBw8TlmEHqoxJdOPMkuLIABgAz48ZbqybIFLwtWnHVkZGKUpIurUpza[2]http://baike.baidu.com/link?url=bcWcMdvPdej9fVlBaNrRAeQsQDcf9oxqkvE2hwg7JXtYZaZx8fD0sWPN1V2kRNScUsSAm-oxaZyatIcStloPxUS-FwEAVcSCwIJLFcW5bTbJ6uFkWgxxJslyKGE9qRFYg2Ymv15yji-4j8YBy0Dul_

试将下列十进制数转换成格雷码:

【答案】:(10101)2=(11111)G$(11111)2=(10000)G$(11000)2=(10100)G$(111101)2=(100011)G

十进制数6.25的BCD码,余3码,格雷码分别是多少

(6.25)10>(0110.0010 0101)BCD(6.25)10>(1101.0111 1100)余三(6.25)10>(0101.0011 0111)格雷

将十进制数695转化成格雷码

采纳答案,是错误的。695 的格雷码,应该是 9 位二进制数。先把十进制数695转化二进制数:1010110111再逐位转换,变成格雷码,即可。

十进制数-27存储为什么是1?

对于十进制的数-27,在寄存器内是:1,1100101。计算机存储负数采用补码的存储形式,所以我们要先计算出-27的原码形式:运用十进制转二进制的方法转为二进制形式为:1,0011011。然后再转化为补码,原码转化为补码的方法为将原码初符号位全部取反然后再加1。所以得出存储的补码形式:1,0011011→1,1100100+1=1,1100101。扩展资料:补码的性质:以补码定义式为基础,沿数轴列出典型的真值、原码与补码表示,可清楚了解补码的有关性质 。1、在补码表示中,最高位x0(符号位)表示数的正负,在形式上与原码相同,即 0正 1负。但补码的符号位是数值的一部分,由补码定义式计算而得。例如,负小数补码中为 x0为1,这个 1是真值X(负)加模 2后产生。2、在补码表示中,数 0只有一种表示,[+0]补 =[-0]补 =0.000……0。3、负数补码表示的范围比原码稍宽,多一种数码组合。对于定点数,若为纯小数,表示范围为:-1~1-2^(-n),若为纯整数,表示范围为:-2^n~2^n-1。原码求补码:正数:正整数的补码是其二进制表示,与原码相同。例:+9的补码是00001001。负数:求负整数的补码,将其原码除符号位外的所有位取反(0变1,1变0,符号位为1不变)后加1。例:求-5的补码。-5对应带符合位负数5(10000101)→除符号位外所有位取反(11111010)→加00000001(11111011)。所以-5的补码是11111011。0的补码:数0的补码表示是唯一的。[+0]补=[+0]反=[+0]原=00000000。[ -0]补=11111111+1=00000000。参考资料来源:百度百科-补码

求十进制数12,0,—0,—128的补码

你好正数的补码等于原数的二进制表示,即原码负数的补码等于其绝对值的原码各位取反,然后整个数加1的数值。12:000011000:00000000-0:00000000-128:10000000希望对你有帮助如有疑问,欢迎追问望采纳~

汇编语言编写完整的程序求N!,可以自由输入n的值,输出为十进制数

.MODEL SMALLCode Segment Assume CS:Code,DS:codeCR equ 000DHLF equ 000AHKBBack equ 0008H; -------------------------------------; 功能:显示指定地址(Str_Addr)的字符串; 入口:; Str_Addr=字符串地址(要求在数据段); 用法: Output Str_Addr; 用法举例:Output PromptStrOutput MACRO Str_Addr lea dx,Str_Addr mov ah,9 int 21h EndM; -------------------------------------; 功能:输出一个字符 ; 入口:dl=要显示的字符 Output_Chr proc Near push ax mov ah,02h int 21h pop ax ret Output_Chr endp ; -------------------------------------; 功能:输出回车换行Output_CTLF proc Near push ax push dx mov ah,02h mov dl,0dh int 21h mov dl,0ah int 21h pop dx pop ax retOutput_CTLF endp ; -------------------------------------; 功能:取光标位置; 入口:无; 出口:DH=行号,DL=列号GetCursor Proc Near PUSH AX PUSH BX PUSH CX XOR BX,BX MOV AH,3 INT 10H MOV Cursor_Row,DH MOV Cursor_Col,DL POP CX POP BX POP AX RETCursor_Row DB ?Cursor_Col DB ?GetCursor EndP; -------------------------------------; 功能:置光标位置; 入口:Cursor_Row=行坐标; Cursor_Col: 列坐标)SetCursor Proc Near PUSH CX PUSH BX PUSH AX MOV DH,Cursor_Row MOV DL,Cursor_Col XOR BX,BX MOV AH,2 INT 10H POP AX POP BX POP CX RETSetCursor EndP; -------------------------------------; 功能:键盘输入一个指定位数的十进制数字,将其转换成二进制数并保存在指定的内存单元。; 由于限定最大数据类型为字,所以,数字位数最多:5,最大无符号数:65536; 约定:直接回车,视为数字0; 入口:@@Digits=数字位数;di=保存输入的数字首地址; @@Type_Data=保存的数据类型,B=字节类型,W=字类型。; 出口:转换后的二进制数保存在di所指的单元Input_Digit Proc Near push dx push cx push bx push di lea di,@@Save_Tmp push di cld mov cl,@@Digits xor ch,ch push cx@@Input: call GetCursor ;取光标位置 mov ah,1 ;从键盘接受一个字符 int 21h cmp al,CR ;若键入的是回车,已经键入的数字不足N位 jz @@ASC_Dec ;转去处理已经键入的数字 cmp al,KBBack jz @@KB_Back ;若是回空键,重新输入 cmp al,"0" jb @@KBBack ;若低于数字"0",重新输入 cmp al,"9" ja @@KBBack ;若低于数字"9",重新输入 jmp @@Save_Dig@@KB_Back: dec Cursor_Col inc cx dec di@@KBBack: call SetCursor ;置光标位置 jmp @@Input@@Save_Dig: and al,0fh ;转换成二进制数 stosb ;保存 loop @@Input ;接受下一个数字@@ASC_Dec: mov ax,cx pop cx pop si sub cx,ax ;实际输入的数字位数 xor bp,bp xor dx,dx xor ax,ax jcxz @@Save_Ret ;若直接回车,没有输入任何数字,按输入"0"处理 dec cx ;实际输入的数字位数减1,准备把输入的这一串数字转换成二进制数 jcxz @@One_Digit ;若输入的数字只有一位,转去直接保存这个二进制数 mov bx,10@@Mul_Ten: lodsb cbw add ax,bp mul bx mov bp,ax loop @@Mul_Ten@@One_Digit: lodsb cbw add ax,bp@@Save_Ret: pop di cmp @@Type_Data,"B" ;字节类型? jz $+5 stosw jmp $+3 stosb pop bx pop cx pop dx ret@@Digits db ? ;十进制数字位数@@Type_Data db "B" ;保存的数据类型。B=字节类型,W=字类型@@Save_Tmp db 16 dup(?)Input_Digit EndP; -------------------------------------; 功能:把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示; 入口:AX=二进制数 ; 出口:在当前光标位置显示转换后的ASCII码数字 Dec_ASCII Proc Near push dx push bx push di mov bx,10 lea di,@@Temp_Save[6] mov byte ptr [di],"$" dec di cld @@Divide: xor dx,dx div bx or dl,30h mov [di],dl dec di test ax,0ffffh jnz @@Divide inc di push di pop dx mov ah,9 int 21h pop di pop bx pop dx ret @@Temp_Save db 7 dup(?)Dec_ASCII EndP; -------------------------------------; 加法运算Addition Proc Near mov ax,Number1 call Dec_ASCII ;把AX中的二进制无符号数转换成显式的十进制ASCII码,并送显示屏显示 mov dl,"+" call Output_Chr ;显示一个加号 mov ax,Number2 call Dec_ASCII ;显示第二个数 mov dl,"=" call Output_Chr ;显示一个等号 mov ax,Number1 add ax,Number2 ;Number1+Number2→AX call Dec_ASCII ;显示和 retAddition EndP; -------------------------------------; 减法运算Subtration Proc Near mov ax,Number1 call Dec_ASCII mov dl,"-" call Output_Chr ;显示一个减号 mov ax,Number2 call Dec_ASCII ;显示第二个数 mov dl,"=" call Output_Chr ;显示一个等号 mov ax,Number1 sub ax,Number2 ;Number1-Number2→AX call Dec_ASCII ;显示差 retSubtration EndP; -------------------------------------; 乘法运算(请事先算好了,否则,容易导致乘积超过16位寄存器能够表示的范围)Multiple Proc Near mov ax,Number1 call Dec_ASCII mov dl,"*" call Output_Chr ;显示一个乘号 mov ax,Number2 call Dec_ASCII ;显示第二个数 mov dl,"=" call Output_Chr ;显示一个等号 mov ax,Number1 mul Number2 ;Number1*Number2→AX call Dec_ASCII ;显示乘积(假定乘积不超过16位寄存器能够表示的范围) retMultiple EndP; -------------------------------------; 除法运算Division Proc Near mov ax,Number1 call Dec_ASCII mov dl,"/" call Output_Chr ;显示一个除号 mov ax,Number2 call Dec_ASCII ;显示第二个数 mov dl,"=" call Output_Chr ;显示一个等号 xor dx,dx mov ax,Number1 div Number2 ;Number1/Number2→AX(商),DX(余数) call Dec_ASCII ;显示商数的整数部分 test dx,0ffffh ;判断余数是否为0 jnz $+3 ;不能整除,计算余数 ret push dx mov cx,6 mov dl,"."Disp_Dot: call Output_Chr ;显示一个等号 loop Disp_Dot pop ax ;余数 call Dec_ASCII ;显示余数部分 retDivision EndP; -------------------------------------Number1 dw ?Number2 dw ?prompt_One db "Please the first number: $"prompt_Two db "Please the second number: $"Press_Key db 13,10,13,10,"The complated. Press any key to exit...$" Start: push cs pop ds push cs pop es ;使数据段、附加段与代码段同段; -------------------------------------; 输入两个十进制数 Output prompt_One ;提示输入第一个数 mov @@Digits,4 ;十进制数字位数 mov @@Type_Data,"W" ;保存的数据类型。B=字节类型,W=字类型 lea di,Number1 ;变量Number1的地址 call Input_Digit ;从键盘接受一个N位数字 call Output_CTLF ;输出一个回车、换行 Output prompt_Two ;提示输入第一个数 lea di,Number2 ;变量Number1的地址 call Input_Digit ;从键盘接受一个N位数字 call Output_CTLF ;输出一个回车、换行 call Output_CTLF ;输出一个回车、换行; ------------------------------------- call Addition ;加法运算 call Output_CTLF ;显示一个回车、换行 call Subtration ;减法运算 call Output_CTLF ;显示一个回车、换行 call Multiple ;乘法运算 call Output_CTLF ;显示一个回车、换行 call Division ;除法运算; -------------------------------------Exit_Proc: Output Press_Key ;提示操作完成,按任意键结束程序 mov ah,1 int 21h mov ah,4ch ;结束程序 int 21hCode Ends END Start ;编译到此结束

如何使用matlab将16进制数转化为16位的2进制数之后忽略2进制数的最高两位,再转成带符号的十进制数呢

clearfid=fopen("文件名","r");a=fscanf(fid,"%s");fclose(fid);b=reshape(a,[4,length(a)/4])";c=uint16(hex2dec(b));x=dec2bin(c);s=bitget(c,14);c=bitset(c,15,s);c=bitset(c,16,s);out=zeros(size(c));for ii=1:size(c,1);if s(ii) out(ii)=double(c(ii))-2^16;else out(ii)=double(c(ii));endendout是最后的输出