Classes: Dealing with Complex Numbers

Sort by

recency

|

255 Discussions

|

  • + 0 comments

    import math class Complex(object): def init(self, real, imaginary): self.real = real self.imaginary = imaginary

    def __add__(self, no):
        real = self.real + no.real
        imaginary = self.imaginary + no.imaginary
        return Complex(real,imaginary)
    
    def __sub__(self, no):
        real = self.real - no.real
        imaginary = self.imaginary - no.imaginary
        return Complex(real,imaginary)
    
    def __mul__(self, no):
        real = (self.real*no.real - self.imaginary*no.imaginary)
        imaginary = (self.real*no.imaginary + self.imaginary*no.real)
        return Complex(real,imaginary)
    
    def __truediv__(self, no):
        try:
            real = (self.real*no.real + self.imaginary*no.imaginary)/((no.real)**2 + (no.imaginary)**2)
            imaginary = (self.imaginary*no.real - self.real*no.imaginary)/((no.real)**2 + (no.imaginary)**2)
            return Complex(real,imaginary)
        except ZeroDivisionError as e:
            return e
    
    def mod(self):
        return Complex(math.sqrt(self.real**2 + self.imaginary**2),0)
    
    
    def __str__(self):
    
        if self.imaginary == 0:
            result = "%.2f+0.00i" % (self.real)
        elif self.real == 0:
            if self.imaginary >= 0:
                result = "0.00+%.2fi" % (self.imaginary)
            else:
                result = "0.00-%.2fi" % (abs(self.imaginary))
        elif self.imaginary > 0:
            result = "%.2f+%.2fi" % (self.real, self.imaginary)
        else:
            result = "%.2f-%.2fi" % (self.real, abs(self.imaginary))
        return result
    
  • + 0 comments
    class Complex(object):
        
        def __init__(self, real, imaginary):
            super().__init__()
            self.real = real
            self.imaginary = imaginary
            
        def __add__(self, no):
            return str(Complex(self.real + no.real, self.imaginary + no.imaginary))
            
        def __sub__(self, no):
            return str(Complex(self.real - no.real, self.imaginary - no.imaginary))
            
        def __mul__(self, no):
            return str(Complex((self.real * no.real) - (self.imaginary * no.imaginary) ,
                     (self.real * no.imaginary) + (self.imaginary * no.real)))
             
        def __truediv__(self, no):
            return str(Complex(((self.real * no.real) + (self.imaginary * no.imaginary)) / (no.imaginary**2 + no.real**2),((self.imaginary * no.real) - (self.real * no.imaginary) ) / (no.imaginary**2 + no.real**2)))
            
        def mod(self):
            return str(Complex((self.real**2 + self.imaginary**2)**0.5,0))
    
  • + 0 comments

    import math

    class Complex(object): def init(self, real, imaginary): self.real = real self.imaginary = imaginary
    def add(self, no): return Complex(self.real + no.real, self.imaginary + no.imaginary) def sub(self, no): return Complex(self.real - no.real, self.imaginary - no.imaginary)
    def mul(self, no): realpart = self.real*no.real - self.imaginary*no.imaginary imaginarypart = self.real*no.imaginary + no.real*self.imaginary return Complex(realpart, imaginarypart) def truediv(self, no): denom = no.real**2 + no.imaginary**2 realpart = (self.real*no.real + self.imaginary*no.imaginary)/denom imaginarypart = (no.real*self.imaginary-self.real*no.imaginary)/denom return Complex(realpart, imaginarypart) def mod(self): return Complex(math.sqrt(self.real**2 + self.imaginary**2), 0) def str(self): if self.imaginary == 0: result = "%.2f+0.00i" % (self.real) elif self.real == 0: if self.imaginary >= 0: result = "0.00+%.2fi" % (self.imaginary) else: result = "0.00-%.2fi" % (abs(self.imaginary)) elif self.imaginary > 0: result = "%.2f+%.2fi" % (self.real, self.imaginary) else: result = "%.2f-%.2fi" % (self.real, abs(self.imaginary)) return result

    if name == 'main': c = map(float, input().split()) d = map(float, input().split()) x = Complex(*c) y = Complex(*d) print(*map(str, [x+y, x-y, x*y, x/y, x.mod(), y.mod()]), sep='\n')

  • + 0 comments
    import math
    
    
    class Complex(object):
        def __init__(self, real, imaginary):
            self.real = real
            self.imaginary = imaginary
    
        def __add__(self, no):
            if isinstance(no, Complex):
                real = self.real + no.real
                imaginary = self.imaginary + no.imaginary
                return str(self.__class__(real, imaginary))
    
        def __sub__(self, no):
            if isinstance(no, Complex):
                real = self.real - no.real
                imaginary = self.imaginary - no.imaginary
                return str(self.__class__(real, imaginary))
    
        def __mul__(self, no):
            real = (self.real * no.real) - (self.imaginary * no.imaginary)
            imaginary = (self.real * no.imaginary) + (self.imaginary * no.real)
            return str(self.__class__(real, imaginary))
    
        def __truediv__(self, no):
    
            denominator = math.pow(no.real,2) + math.pow(no.imaginary,2)
            real = ((self.real * no.real) + (self.imaginary * no.imaginary)) / denominator
            imaginary = ((self.imaginary * no.real) - (self.real * no.imaginary)) / denominator
            return str(self.__class__(real, imaginary))
    
        def mod(self):
            real = math.sqrt(math.pow(self.real,2) + math.pow(self.imaginary,2))
            imaginary = 0
            return str(self.__class__(real, imaginary))
    
    
        def __str__(self):
            if self.imaginary == 0:
                result = "%.2f+0.00i" % (self.real)
            elif self.real == 0:
                if self.imaginary >= 0:
                    result = "0.00+%.2fi" % (self.imaginary)
                else:
                    result = "0.00-%.2fi" % (abs(self.imaginary))
            elif self.imaginary > 0:
                result = "%.2f+%.2fi" % (self.real, self.imaginary)
            else:
                result = "%.2f-%.2fi" % (self.real, abs(self.imaginary))
            return result
    
  • + 0 comments
    import math
    
    class Complex(object):
        def __init__(self, real, imaginary):
            self.real = real
            self.imaginary = imaginary        
        def __add__(self, no):
            return Complex(self.real + no.real, self.imaginary + no.imaginary)
        def __sub__(self, no):
            return Complex(self.real - no.real, self.imaginary - no.imaginary)        
        def __mul__(self, no):
            realpart = self.real*no.real - self.imaginary*no.imaginary
            imaginarypart = self.real*no.imaginary + no.real*self.imaginary
            return Complex(realpart, imaginarypart)
        def __truediv__(self, no):
            denom = no.real**2 + no.imaginary**2
            realpart = (self.real*no.real + self.imaginary*no.imaginary)/denom
            imaginarypart = (no.real*self.imaginary-self.real*no.imaginary)/denom
            return Complex(realpart, imaginarypart)
        def mod(self):
            return Complex(math.sqrt(self.real**2 + self.imaginary**2), 0)
        def __str__(self):
            if self.imaginary == 0:
                result = "%.2f+0.00i" % (self.real)
            elif self.real == 0:
                if self.imaginary >= 0:
                    result = "0.00+%.2fi" % (self.imaginary)
                else:
                    result = "0.00-%.2fi" % (abs(self.imaginary))
            elif self.imaginary > 0:
                result = "%.2f+%.2fi" % (self.real, self.imaginary)
            else:
                result = "%.2f-%.2fi" % (self.real, abs(self.imaginary))
            return result
    
    if __name__ == '__main__':
        c = map(float, input().split())
        d = map(float, input().split())
        x = Complex(*c)
        y = Complex(*d)
        print(*map(str, [x+y, x-y, x*y, x/y, x.mod(), y.mod()]), sep='\n')