x86 기계 코드, 9 7 바이트
D1 E9 SHR CX, 1 ; divide length in half
AD LODSW ; load next two chars into AH/AL
3A E0 CMP AH, AL ; compare AH and AL
E1 FB LOOPE -5 ; if equal, continue loop
에서 입력 문자열 SI
에서 입력 문자열 길이 CX
. ZF
더블 토크 인 경우 출력 .
또는 완전한 PC DOS 실행 파일로 14 바이트 :
B4 01 MOV AH, 01H ; DOS read char from STDIN (with echo)
CD 21 INT 21H ; read first char into AL
92 XCHG DX, AX ; put first char into DL
B4 08 MOV AH, 08H ; DOS read char from STDIN (no echo)
CD 21 INT 21H ; read second char into AL
3A C2 CMP AL, DL ; compare first and second char
74 F3 JE -13 ; if the same, continue loop
C3 RET ; otherwise exit to DOS
입력은 STDIN
파이프 또는 대화식을 통해 이루어 집니다. 2 배가 아닌 문자가 감지 될 때까지 "2 배"입력을 반향합니다.이 시점에서 I / O 규칙이 약간 구부러 질 수 있지만 보너스 답변 일뿐입니다.
다음을 사용하여 ISDBL2.COM을 빌드하고 테스트하십시오 xxd -r
.
00000000: b401 cd21 92b4 08cd 213a c274 f3c3 ...!....!:.t..
원본 24 바이트 는 PC DOS 실행 파일을 완성합니다.
D1 EE SHR SI, 1 ; SI to DOS PSP (080H)
AD LODSW ; load string length into AL
D0 E8 SHR AL, 1 ; divide length in half
8A C8 MOV CL, AL ; put string length into BL
CLOOP:
AD LODSW ; load next two chars into AH/AL
3A E0 CMP AH, AL ; compare AH and AL
E1 FB LOOPE CLOOP ; if equal, continue loop
DONE:
B8 0E59 MOV AX, 0E59H ; BIOS tty function in AH, 'Y' in AL
74 02 JZ DISP ; if ZF, result was valid double
B0 4E MOV AL, 'N' ; if not, change output char to N
DISP:
B4 0E MOV AH, 0EH
CD 10 INT 10H
C3 RET ; return to DOS
명령 줄에서 입력하고, 'Y'
두 배인 'N'
경우 화면에 출력합니다 ( 그렇지 않은 경우).
다음을 사용하여 ISDBL.COM을 빌드하고 테스트하십시오 xxd -r
.
00000000: d1ee add0 e88a c8ad 3ae0 e1fb b859 0e74 ........:....Y.t
00000010: 02b0 4eb4 0ecd 10c3 ..N.....
크레딧 :