2015-10-15 4 views
-1

ниже - программа, которая делает первую букву каждого предложения в верхнем регистре. Тем не менее, мне нужно изменить эту программу, чтобы она делала любые другие строчные буквы в нижнем регистре. Кроме того, может быть много предложений. До сих пор я заметил, что программа не очень хорошо работает на моем ПК, но, вероятно, это не ошибка моей программы. В любом случае, у меня много проблем, чтобы выяснить, как правильно изменить эту программу, чтобы соответствовать требованиям. Большое вам спасибо заранее!Как преобразовать первую букву каждого предложения в верхний регистр и все остальные буквы в нижний регистр (Сборка)?

.model small 
    .stack 100h 
    .data 

BUFSIZE EQU 4096 ; constant - the size of the buffer 
input db 'data.txt',0 ; default input file 
output db 'result.txt',0 ; default output file 
msg1 db 'Choose data file [data.txt]: $' 
msg2 db 10,13,'Choose result file [rezult.txt]: $' 
msg3 db 10,13,'Error, the file could not be found, working with default file: data.txt $' 
string1 db 11 dup (?) ; the name of input file 
string2 db 11 dup (?) ; the name of result file 
handle1 dw ? ; file handles 
handle2 dw ? 
buffer db BUFSIZE dup (' ') ; buffer 
.code 
     mov ax, @data ; loading data segment 
     mov ds,ax 
     sub cx,cx 
     mov si, 80h 
     mov cl,es:[si] 
     cmp cx, 0 
     mov bx,0  
     je label1 
     inc si 
     inc si 
     dec cx 

read: mov al,es:[si] 
     cmp al,' '  
     je second 
     mov string1[bx],al 
     inc si 
     inc bx 
     loop read 

second: 
     mov string1[bx],0 

     mov bx,0 
     dec cx 

looper: inc si 
      mov al,es:[si] 
      mov string2[bx],al 
      inc bx 
      loop looper 

      mov string2[bx],0 
      mov bx,100h 
      push bx 
      jmp open  

label1: mov ah, 9 
      mov dx, offset msg1 
      int 21h 

named:  mov ah, 1h 
      int 21h 
      cmp al, 13 
      je eof1 
      mov string1[bx],al 
      inc bx 
      jmp named 

eof1:  mov string1[bx],00h 

open:  mov ah, 3dh 
      mov al, 2 
      mov dx, offset string1 
      int 21h 
      mov handle1, ax 
      mov ah, 59h 
      int 21h 
      cmp al, 2 
      je deflt 
      jmp cont 

deflt:  mov ah,9 
      mov dx,offset msg3 
      int 21h 
      mov ah, 3dh 
      mov al, 2 
      mov dx,offset input 
      int 21h 
      mov handle1,ax 

cont:  pop bx 
      cmp bx,100h 
      je creat2 
      mov ah, 9 
      mov dx, offset msg2 
      int 21h 

      mov bx,0000h 

label2: mov ah, 1h 
      int 21h 
      cmp al, 13 
      je eof2 
      mov string2[bx],al 
      inc bx 
      jmp label2 

eof2:  mov string2[bx],0 
      cmp bx, 0 
      je creat1 
      jmp creat2 

creat1: mov ah, 3ch 
      mov cx, 0 
      mov dx, offset output 
      int 21h 
      mov handle2, ax 
      mov ah, 3eh 
      mov bx, handle2 
      int 21h 
      mov ah, 3dh 
      mov al, 2 
      mov dx, offset output 
      int 21h 
      mov handle2, ax 
      jmp read_s 

creat2: mov ah, 3ch 
      mov cx, 0 
      mov dx, offset string2 
      int 21h 
      mov handle2, ax 
      mov ah, 3eh 
      mov bx, handle2 
      int 21h 
      mov ah, 3dh 
      mov al, 2 
      mov dx, offset string2 
      int 21h 
      mov handle2, ax 

doin: 

read_s: mov ah, 3fh 
      mov bx, handle1 
      mov cx, BUFSIZE 
      mov dx, offset buffer 
      int 21h 
      cmp ax, 0 
      je theend 
      mov bx,ax 

      cmp buffer[0], 'z' 
      ja searching 
      cmp buffer[0], 'a' 
      jb searching 
      sub buffer[0], 32 
      dec bx 
cc: 

edit:  cmp buffer[bx], '?' 
      je higher 
      cmp buffer[bx], '!' 
      je higher 
      cmp buffer[bx], '.' 
      je higher 
      jmp searching 

higher: cmp buffer[bx+1], 'a' 
      jae lower 
      jmp searching 

lower: cmp buffer[bx+1], 'z' 
      jbe changing; 
      jmp searching  

changing: sub buffer[bx+1], 32 

searching: dec bx ; 
      jnz cc 

      mov cx, ax 
      mov ah, 40h 
      mov bx, handle2 
      mov dx, offset buffer 
      int 21h 
      jmp doin 


theend: mov ah, 3eh 
      int 21h 
      mov bx, handle1 
      int 21h 

      mov ah, 4ch  
      int 21h 
end 

ответ

1

Ну, есть два случая, в которых вы должны обеспечить характер является капитал - для первого символа в строке, и для любого полукокса, что следует «». Каждый другой символ должен быть строчным.

Start, сделав функцию для добавления 'A' - 'a' (32) к полукокса, если символ находится в диапазоне [a..z], назовем его toupper.Now дублировать эту функцию и изменить его так, чтобы он вычитает 'A'-'a' (32) из char, если он попадает в диапазон [A..Z].

Теперь просто пройдите через строку, загрузив каждого персонажа. Если это нулевой ограничитель, все готово. Если это первый символ, запишите его, а затем сохраните как последний символ, загрузите другой символ и повторите попытку. Если это не null и его не первый символ, проверьте, является ли последний символ пробелом. Если это так, запишите символ, сохраните его как последний, а затем верните, чтобы загрузить следующий символ. Если, однако, последний символ не был пробелом, сделайте нижний регистр символа, сохраните его как последний символ и затем верните его для загрузки следующего.

Вы можете инициализировать переменную lastChar равным 0, чтобы определить, является ли текущий символ первым в строке. Кроме того, несколько комментариев и несколько более значимых имен ярлыков заставят ваш код легче вернуться к более поздней дате или более легко прочитать для кого-либо еще. ;) Его привычка стоит попасть.

Вот пример работы. Выходной сигнал This Is My Message

;========================================== 
; nasm toupper.asm -f bin -o toupper.com 
;========================================== 
[BITS 16] 
[ORG 0x100]  ; DOS .com program, no header, CS=DS 
EntryPoint: 
    mov  ax, 0x03    ; set text mode 3 - we should already be in this mode, done to clear the screen 
    int  0x10 

    push word myMessage 
    call makePrettyCase 

    push word myMessage 
    call printString 

    int  0x20     ; exit back to dos 

;void printString(*str) 
printString: 
    push bp 
    mov  bp, sp 
    add  bp, 4 
    mov  si, [bp+0]    ; ds:si ---> string 
.getChar: 
    lodsb 
    test al, 0xff    ; sets the flags as if we did 'and al, 0xff' - if the zero flag is set, there are no bits set in al, i.e it's 0 
    jz  .printStringDone 
    mov  ah, 0xe 
    int  0x10 
    jmp  .getChar 
.printStringDone: 
    pop  bp 
    ret  2 

; input: 
;  AL = char 
; outpt: 
;  if al if an alpha char, ensures it is in range A-Z 
toupper: 
    cmp  al, 'a' 
    jb  .toupperDone 
    cmp  al, 'z' 
    ja  .toupperDone 
    add  al, 'A' - 'a'  
.toupperDone: 
    ret 

; input: 
;  AL = char 
; outpt: 
;  if al if an alpha char, ensures it is in range a-z 
tolower: 
    cmp  al, 'A' 
    jb  .tolowerDone 
    cmp  al, 'Z' 
    ja  .tolowerDone 
    sub  al, 'A' - 'a'  
.tolowerDone: 
    ret 

; void makePrettyCase(char *string) 
makePrettyCase: 
    push bp 
    mov  bp, sp 
    add  bp, 4       ; add 2 for the bp we just saved, and 2 for the return address. bp now points at out input var, a pointer to the string 
    pusha 
    mov  si, [bp+0]      ; point source index to string 
    mov  di, si       ; point dest index to string 
    xor  dl, dl       ; DL = lastChar, holds 0 for the first char in the string 
    mov  dh, ' '       ; DH = spaceChar (' ') - holds the ascii code for a space 
.getNextChar: 
    lodsb         ; ds:[si] --> al, si = si+1 
    test al, 0xff 
    jz  .makePrettyCaseDone 
.checkIfFirstInString:      ; if so, capitalize 
; cmp  byte [lastChar], 0 
    cmp  dl, 0 
    jne  .checkIfLastWasSpace 
    jmp  .makeUpper 
.checkIfLastWasSpace:      ; if so, capitalize 
    ;cmp  byte [lastChar], spaceChar 
    cmp  dl, dh 
    jne  .makeLower 
.makeUpper: 
    call toupper 
    stosb         ; al --> es:[di], di = di+1 
    mov  dl, al       ; save this char as our lastChar 
    ;mov  byte [lastChar], al 
    jmp  .getNextChar 
.makeLower: 
    call tolower 
    stosb         ; al --> es:[di], di = di+1 
    mov  dl, al       ; save this char as our lastChar 
    ;mov  byte [lastChar], al 
    jmp  .getNextChar 
.makePrettyCaseDone: 
    popa 
    pop  bp 
    ret  2        ; return and remove the 2 bytes of the input var from the stack 

;========================================== 
[section .data] 
myMessage  db  "THIS IS MY MESSAGE",0