Hi,
My program hangs in sorting loop. I thought its a integer size limit but other post says that Python is good at large numbers. It works fine for random values but random values generation (in my program) actually don’t use large numbers (i.e. seed). Even the sorting is not using large numbers, so it might be program logic but also a memory problem which python is not complaining.
Any way somebody please provide me a practical solution.
Program works fine with small values.
import random
import psutil
import os
class SSSort:
arr = [] # class var access by className.arr
def __init__(self, n):
self.n = n
def generate1000000_5digit_RandomNum(self):
for i in range(self.n):
num = random.randint(10000, 99999)
SSSort.arr.append(num)
for j in range(self.n):
print("random {0}".format(SSSort.arr[j]))
def find_the_min_element(self, i):
min = i
for j in range(i+1, self.n):
if (SSSort.arr[j] < SSSort.arr[min]):
min = j
return min
#print("min {}".format(min))
def selectionSort(self):
for i in range(self.n):
min = self.find_the_min_element(i)
#swap min and ith element of array
temp = SSSort.arr[min]
SSSort.arr[min] = SSSort.arr[i]
SSSort.arr[i] = temp
for i in enumerate(SSSort.arr):
print(i)
def main(self):
self.generate1000000_5digit_RandomNum()
self.selectionSort()
if __name__ == "__main__":
objSSSort = SSSort(1000000)
objSSSort.main()
Output: shows the random values but hangs up in the sorting loop
Somebody please solve my problem.
Zulfi.