The nice thing about two's complement arithmetic is that we can just work as if it were all in base 2 since -x (where x is positive) is represented by in other words, modulo negative numbers represent themselves. However, if overflow occurs, then we must recognize an error. Let us look at some examples, where n = 5 (i.e., we use five bits to represent numbers between - 15 and 15 ). To add 5 + 7, we write 00101+001111=01100
In base 2, which gives us the correct answer, 12. However, if we try to add 13+7 we obtain 01101+00111=10100 which represents -12 rather than 20 , so we report an overflow error. (Of course these two numbers are congruent modulo 32.) Similarly, for 5+(-7), we write 00101+11001=11110 in base 2, and 11110 is the two's complement representation of -2 the right answer. For (- 5)+ (- 7) we write 11011+11001= 110100 in base 2, if we ignore the extra 1 in the left-most column (which doesn't exist), then this is the two's complement representation of 12 again the right answer.
To summarize, to obtain the two's complement representation of the sum of two integers given in two's complement representation, add them as if they were binary integers, and ignore any carry out of the left-most column. However, if the left-most digits of the two addends agree and the left-most digit of the answer is different from their common value, then an overflow has occurred, and the answer is not valid.