mirror of
https://github.com/DeaDvey/mathgenerator.git
synced 2025-11-28 14:35:23 +01:00
Added 2's complement
This commit is contained in:
@@ -71,3 +71,4 @@ from .multiplyComplexNumbersFunc import *
|
|||||||
from .geomProgrFunc import *
|
from .geomProgrFunc import *
|
||||||
from .geometricMeanFunc import *
|
from .geometricMeanFunc import *
|
||||||
from .harmonicMeanFunc import *
|
from .harmonicMeanFunc import *
|
||||||
|
from .binary2sComplement import *
|
||||||
26
mathgenerator/funcs/binary2sComplement.py
Normal file
26
mathgenerator/funcs/binary2sComplement.py
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
from .__init__ import *
|
||||||
|
|
||||||
|
def binary2sComplementFunc(maxDigits=10):
|
||||||
|
digits = random.randint(1, maxDigits)
|
||||||
|
question = ''.join([str(random.randint(0, 1)) for i in range(digits)]).lstrip('0')
|
||||||
|
|
||||||
|
answer = []
|
||||||
|
for i in question:
|
||||||
|
answer.append(str(int(not bool(int(i)))))
|
||||||
|
|
||||||
|
carry = True
|
||||||
|
j = len(answer) - 1
|
||||||
|
while j >= 0:
|
||||||
|
if answer[j] == '0':
|
||||||
|
answer[j] = '1'
|
||||||
|
carry = False
|
||||||
|
break
|
||||||
|
answer[j] = '0'
|
||||||
|
j -= 1
|
||||||
|
|
||||||
|
if j == 0 and carry == True:
|
||||||
|
answer.insert(0, '1')
|
||||||
|
|
||||||
|
problem = "2's complement of " + question + " ="
|
||||||
|
solution = ''.join(answer).lstrip('0')
|
||||||
|
return problem, solution
|
||||||
@@ -156,3 +156,4 @@ complexNumMultiply = Generator("Multiplication of 2 complex numbers", 64, "(x +
|
|||||||
geometricprogression=Generator("Geometric Progression", 65, "Initial value,Common Ratio,nth Term,Sum till nth term =", "a,r,ar^n-1,sum(ar^n-1", geomProgrFunc)
|
geometricprogression=Generator("Geometric Progression", 65, "Initial value,Common Ratio,nth Term,Sum till nth term =", "a,r,ar^n-1,sum(ar^n-1", geomProgrFunc)
|
||||||
geometricMean=Generator("Geometric Mean of N Numbers",66,"Geometric mean of n numbers A1 , A2 , ... , An = ","(A1*A2*...An)^(1/n) = ans",geometricMeanFunc)
|
geometricMean=Generator("Geometric Mean of N Numbers",66,"Geometric mean of n numbers A1 , A2 , ... , An = ","(A1*A2*...An)^(1/n) = ans",geometricMeanFunc)
|
||||||
harmonicMean=Generator("Harmonic Mean of N Numbers",67,"Harmonic mean of n numbers A1 , A2 , ... , An = "," n/((1/A1) + (1/A2) + ... + (1/An)) = ans",harmonicMeanFunc)
|
harmonicMean=Generator("Harmonic Mean of N Numbers",67,"Harmonic mean of n numbers A1 , A2 , ... , An = "," n/((1/A1) + (1/A2) + ... + (1/An)) = ans",harmonicMeanFunc)
|
||||||
|
binary2sComplement = Generator("Binary 2's Complement", 68, "2's complement of 11010110 = ", "101010", binary2sComplementFunc)
|
||||||
Reference in New Issue
Block a user