-
Notifications
You must be signed in to change notification settings - Fork 67
Expand file tree
/
Copy pathgrouped_frequency.py
More file actions
52 lines (44 loc) · 1.27 KB
/
grouped_frequency.py
File metadata and controls
52 lines (44 loc) · 1.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
'''
grouped_frequency.py
Create a grouped frequency table from a list of numbers
'''
def create_classes(numbers, n):
low = min(numbers)
high = max(numbers)
# width of each class
width = (high - low)/n
classes = []
a = low
b = low + width
classes = []
while a < (high-width):
classes.append((a, b))
a = b
b = a + width
# The last class may be of size
# less than width
classes.append((a, high+1))
return classes
def classify(numbers, classes):
# Create a list with the same number of elements
# as the number of classes
count = [0]*len(classes)
for n in numbers:
for index, c in enumerate(classes):
if n >= c[0] and n < c[1]:
count[index] += 1
break
return count
def read_data(filename):
numbers = []
with open(filename) as f:
for line in f:
numbers.append(float(line))
return numbers
if __name__ == '__main__':
num_classes = int(input('Enter the number of classes: '))
numbers = read_data('marks.txt')
classes = create_classes(numbers, num_classes)
count = classify(numbers, classes)
for c, cnt in zip(classes, count):
print('{0:.2f} - {1:.2f} \t {2}'.format(c[0], c[1], cnt))