• Skip to primary navigation
  • Skip to main content
  • Skip to primary sidebar
  • Skip to footer
projectsgeek

ProjectsGeek

Download Mini projects with Source Code, Java projects with Source Codes

  • Home
  • Java Projects
  • C++ Projects
  • VB Projects
  • PHP projects
  • .Net Projects
  • NodeJs Projects
  • Android Projects
    • Project Ideas
      • Final Year Project Ideas
      • JSP Projects
  • Assignment Codes
    • Fundamentals of Programming Language
    • Software Design Laboratory
    • Data Structure and Files Lab
    • Computer Graphics Lab
    • Object Oriented Programming Lab
    • Assembly Codes
  • School Projects
  • Forum

How to find 1’s complement of a number

June 22, 2013 by ProjectsGeek Leave a Comment

Find 1’s complement of a number

 

Algorithm for finding 1’s Complement

 

Step I : Initialize the data memory.

Step II : Load the number in AX.

Step III : Initialize counter = 16.

Step IV : Rotate number by 1 bit position to left with carry.

Step V : Complement carry.

Step VI : Decrement counter.

Step VII : Check if count = 0. If yes, go to step VIII else goto Step IV.

Step VIII : Rotate number by 1 bit position to left with carry to restore original carry back.

Step IX : Display 1’s complement.

Step X : Stop.

Program Code 1’s complement of a number:

.model small

.data

a dw 1234H

.code

mov ax, @data           ; Initialize data section

mov ds, ax

mov ax, a               ; Load number1 in ax

mov cx, 16              ; Load CX with count

up : rcl ax, 1          ; Rotate ax by 1bit to left with carry

cmc                     ; find 1's complement of bit

loop up                 ; check if all bits complemented, if not goto up

rcl ax, 1               ; return carry back to original position

mov ch, 04h             ; Count of digits to be displayed

mov cl, 04h             ; Count to roll by 4 bits

mov bx, ax              ; Result in reg bx

l2: rol bx, cl          ; roll bl so that msb comes to lsb

mov dl, bl              ; load dl with data to be displayed

and dl, 0fH             ; get only lsb

cmp dl, 09              ; check if digit is 0-9 or letter A-F

jbe l4

add dl, 07              ; if letter add 37H else only add 30H

l4: add dl, 30H

mov ah, 02              ; Function 2 under INT 21H

; (Display character)

int 21H

dec ch                  ; Decrement Count

jnz l2

mov ah, 4cH             ; Terminate Program

int 21H

end

 

Other Projects to Try:

  1. Add 8 Bit BCD Numbers
  2. Multiply Two 8 Bit Numbers using Add and Shift Method
  3. Count the Number of 1s in a Register
  4. How to find 2’s Complement of a Number
  5. 2s Complement of a Numbers Assembly Code

Filed Under: Assembly Codes Tagged With: Assembly Codes

Reader Interactions

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Primary Sidebar

Tags

.Net Projects Download Android Project Ideas Android Projects Angular 2 Assembly Codes C # Projects C & C++ Projects C++ Projects Class Diagrams Computer Graphics Database Project Data Mining Projects DataScience Projects Datastructure Assignments Download Visual Basic Projects Electronics project Hadoop Projects Installation Guides Internet of Things Project IOS Projects Java Java Interview Questions Java Projects JavaScript JavaScript Projects java tutorial JSON JSP Projects Mechanical Projects Mongodb Networking Projects Node JS Projects OS Problems php Projects Placement Papers Project Ideas Python Projects seminar and presentation Struts

Search this Website


Footer

Download Java Project
Download Visual Basic Projects
Download .Net Projects
Download VB Projects
Download C++ Projects
Download NodeJs Projects
Download School Projects
Download School Projects
Ask Questions - Forum
Latest Projects Ideas
Assembly Codes
Datastructure Assignments
Computer Graphics Lab
Operating system Lab
australia-and-India-flag
  • Home
  • About me
  • Contact Form
  • Submit Your Work
  • Site Map
  • Privacy Policy