|
|
@ -128,24 +128,29 @@ def load_input(val): |
|
|
|
cur_meet_list = cur_meet_list | {int(s)} |
|
|
|
cur_meet_list = cur_meet_list | {int(s)} |
|
|
|
p = Person(cur_beig_id,cur_name, cur_meet_list) |
|
|
|
p = Person(cur_beig_id,cur_name, cur_meet_list) |
|
|
|
persons.append(p) |
|
|
|
persons.append(p) |
|
|
|
persons = sorted(persons, key=lambda person: len(person.meet_set)) |
|
|
|
|
|
|
|
|
|
|
|
def get_present_persons(): |
|
|
|
|
|
|
|
global persons |
|
|
|
|
|
|
|
return list(filter(lambda p : p.beig_id > 0, persons)) |
|
|
|
|
|
|
|
|
|
|
|
def show_meet_table_data(): |
|
|
|
def show_meet_table_data(): |
|
|
|
global persons |
|
|
|
global persons |
|
|
|
html = "Всего участников: " + str(len(persons)) + "<br/>" |
|
|
|
html = "Всего участников: " + str(len(persons)) + "<br/>" |
|
|
|
|
|
|
|
html += "Присутсвуют участников: " + str(len(get_present_persons())) + "<br/>" |
|
|
|
|
|
|
|
|
|
|
|
html += "<table border = 1>" |
|
|
|
html += "<table border = 1>" |
|
|
|
# Первая строка |
|
|
|
# Первая строка |
|
|
|
html += "<tr>" |
|
|
|
html += "<tr>" |
|
|
|
html += "<td></td>" |
|
|
|
html += "<td></td>" |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
html += "<th" + " title="+ p.name + ">" + str(p.beig_id) + "</th>" |
|
|
|
html += "<th" + " title="+ p.name + ">" + str(abs(p.beig_id)) + "</th>" |
|
|
|
html += "</tr>" |
|
|
|
html += "</tr>" |
|
|
|
# Остальные строки |
|
|
|
# Остальные строки |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
html += "<tr>" |
|
|
|
html += "<tr>" |
|
|
|
html += "<th" + " title="+ p.name + ">" + str(p.beig_id) + "</th>" |
|
|
|
html += "<th" + " title="+ p.name + ">" + str(abs(p.beig_id)) + "</th>" |
|
|
|
for ip in persons: |
|
|
|
for ip in persons: |
|
|
|
if p.beig_id in ip.meet_set: |
|
|
|
if abs(p.beig_id) in ip.meet_set: |
|
|
|
html += "<td bgcolor='red'></td>" |
|
|
|
html += "<td bgcolor='red'></td>" |
|
|
|
else: |
|
|
|
else: |
|
|
|
html += "<td></td>" |
|
|
|
html += "<td></td>" |
|
|
@ -202,20 +207,18 @@ def print_result_table(): |
|
|
|
def get_person_by_id(id): |
|
|
|
def get_person_by_id(id): |
|
|
|
global persons |
|
|
|
global persons |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
if p.beig_id == id: |
|
|
|
if abs(p.beig_id) == id: |
|
|
|
return p |
|
|
|
return p |
|
|
|
print("Error", id) |
|
|
|
print("Error", id) |
|
|
|
|
|
|
|
|
|
|
|
def fill_next_table(start_person_id, persons_set, table_size_count): |
|
|
|
def fill_next_table(start_person_id, persons_set, table_size_count, persons): |
|
|
|
global persons |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_persons = [get_person_by_id(start_person_id)] |
|
|
|
result_persons = [get_person_by_id(start_person_id)] |
|
|
|
result_set = {start_person_id} |
|
|
|
result_set = {start_person_id} |
|
|
|
|
|
|
|
|
|
|
|
while(len(result_set) < table_size_count): |
|
|
|
while(len(result_set) < table_size_count): |
|
|
|
search_succes = False |
|
|
|
search_succes = False |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
cur_id = p.beig_id |
|
|
|
cur_id = abs(p.beig_id) |
|
|
|
if cur_id in persons_set: |
|
|
|
if cur_id in persons_set: |
|
|
|
continue |
|
|
|
continue |
|
|
|
if cur_id in result_set: |
|
|
|
if cur_id in result_set: |
|
|
@ -233,7 +236,7 @@ def fill_next_table(start_person_id, persons_set, table_size_count): |
|
|
|
|
|
|
|
|
|
|
|
if not search_succes: |
|
|
|
if not search_succes: |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
cur_id = p.beig_id |
|
|
|
cur_id = abs(p.beig_id) |
|
|
|
if cur_id in persons_set: |
|
|
|
if cur_id in persons_set: |
|
|
|
continue |
|
|
|
continue |
|
|
|
if cur_id in result_set: |
|
|
|
if cur_id in result_set: |
|
|
@ -244,18 +247,19 @@ def fill_next_table(start_person_id, persons_set, table_size_count): |
|
|
|
|
|
|
|
|
|
|
|
return result_set |
|
|
|
return result_set |
|
|
|
|
|
|
|
|
|
|
|
def get_beig_id_set(): |
|
|
|
def get_beig_id_set(persons): |
|
|
|
result = set() |
|
|
|
result = set() |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
result = result | {p.beig_id} |
|
|
|
result = result | {abs(p.beig_id)} |
|
|
|
return result |
|
|
|
return result |
|
|
|
|
|
|
|
|
|
|
|
def fill_tables(): |
|
|
|
def fill_tables(): |
|
|
|
global persons |
|
|
|
|
|
|
|
global tables |
|
|
|
global tables |
|
|
|
tables = [] |
|
|
|
tables = [] |
|
|
|
cur_table_id = 0 |
|
|
|
cur_table_id = 0 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sort_persons = sorted(get_present_persons(), key=lambda person: len(person.meet_set)) |
|
|
|
|
|
|
|
|
|
|
|
all_table_size = 0 |
|
|
|
all_table_size = 0 |
|
|
|
str_table_size = document["table_size"].value.replace(" ", "").split(",") |
|
|
|
str_table_size = document["table_size"].value.replace(" ", "").split(",") |
|
|
|
table_size = [] |
|
|
|
table_size = [] |
|
|
@ -266,16 +270,16 @@ def fill_tables(): |
|
|
|
table_size += [t] |
|
|
|
table_size += [t] |
|
|
|
|
|
|
|
|
|
|
|
table_count = len(table_size); |
|
|
|
table_count = len(table_size); |
|
|
|
beig_id_set = get_beig_id_set() |
|
|
|
beig_id_set = get_beig_id_set(sort_persons) |
|
|
|
|
|
|
|
|
|
|
|
persons_set = set() |
|
|
|
persons_set = set() |
|
|
|
while len(persons_set) != len(persons): |
|
|
|
while len(persons_set) != len(sort_persons): |
|
|
|
if len(persons_set) >= all_table_size: |
|
|
|
if len(persons_set) >= all_table_size: |
|
|
|
break |
|
|
|
break |
|
|
|
|
|
|
|
|
|
|
|
new_person_id = random.sample(list(beig_id_set - persons_set), 1)[0] |
|
|
|
new_person_id = random.sample(list(beig_id_set - persons_set), 1)[0] |
|
|
|
|
|
|
|
|
|
|
|
cur_set = fill_next_table(new_person_id, persons_set, min(table_size[cur_table_id], len(persons) - len(persons_set))) |
|
|
|
cur_set = fill_next_table(new_person_id, persons_set, min(table_size[cur_table_id], len(sort_persons) - len(persons_set)), sort_persons) |
|
|
|
persons_set = persons_set | cur_set |
|
|
|
persons_set = persons_set | cur_set |
|
|
|
tables.append(Table(cur_table_id, cur_set)) |
|
|
|
tables.append(Table(cur_table_id, cur_set)) |
|
|
|
cur_table_id += 1 |
|
|
|
cur_table_id += 1 |
|
|
@ -285,7 +289,7 @@ def fill_persons(): |
|
|
|
global tables |
|
|
|
global tables |
|
|
|
for t in tables: |
|
|
|
for t in tables: |
|
|
|
for p in persons: |
|
|
|
for p in persons: |
|
|
|
if p.beig_id in t.person_set: |
|
|
|
if abs(p.beig_id) in t.person_set: |
|
|
|
p.meet_set = t.person_set | p.meet_set |
|
|
|
p.meet_set = t.person_set | p.meet_set |
|
|
|
|
|
|
|
|
|
|
|
def load_input_table(val): |
|
|
|
def load_input_table(val): |
|
|
|