nyoj2.0 一種排序
阿新 • • 發佈:2019-01-13
題目描述:
現在有很多長方形,每一個長方形都有一個編號,這個編號可以重複;還知道這個長方形的寬和長,編號、長、寬都是整數;現在要求按照一下方式排序(預設排序規則都是從小到大);
1.按照編號從小到大排序
2.對於編號相等的長方形,按照長方形的長排序;
3.如果編號和長都相同,按照長方形的寬排序;
4.如果編號、長、寬都相同,就只保留一個長方形用於排序,刪除多餘的長方形;最後排好序按照指定格式顯示所有的長方形;
輸入描述:
第一行有一個整數 0<n<10000,表示接下來有n組測試資料; 每一組第一行有一個整數 0<m<1000,表示有m個長方形; 接下來的m行,每一行有三個數 ,第一個數表示長方形的編號, 第二個和第三個數值大的表示長,數值小的表示寬,相等 說明這是一個正方形(資料約定長寬與編號都小於10000);
輸出描述:
順序輸出每組資料的所有符合條件的長方形的 編號 長 寬
樣例輸入:
複製
1 8 1 1 1 1 1 1 1 1 2 1 2 1 1 2 2 2 1 1 2 1 2 2 2 1
樣例輸出:
1 1 1 1 2 1 1 2 2 2 1 1 2 2 1
n = int(input()) for i in range(n): lt = [] m = int(input()) for j in range(m): d = {} num = input() num_list = num.split(' ') d['number'] = int(num_list[0]) if int(num_list[1]) > int(num_list[2]): d['width'] = int(num_list[1]) d['height'] = int(num_list[2]) else: d['width'] = int(num_list[2]) d['height'] = int(num_list[1]) lt.append(d) for i1 in range(len(lt) - 1): for j1 in range(len(lt) - i1 - 1): if lt[j1]['number'] > lt[j1 + 1]['number']: t = lt[j1] lt[j1] = lt[j1 + 1] lt[j1 + 1] = t elif lt[j1]['number'] == lt[j1 + 1]['number']: if lt[j1]['width'] > lt[j1 + 1]['width']: t = lt[j1] lt[j1] = lt[j1 + 1] lt[j1 + 1] = t elif lt[j1]['width'] == lt[j1 + 1]['width']: if lt[j1]['height'] > lt[j1 + 1]['height']: t = lt[j1] lt[j1] = lt[j1 + 1] lt[j1 + 1] = t elif lt[j1]['height'] == lt[j1 + 1]['height']: lt[j1]['number'] = 0 lt[j1]['width'] = 0 lt[j1]['height'] = 0 for dt in lt: if dt['number'] != 0: print(dt['number'],dt['width'],dt['height'],sep=' ')