ポインタのソート
明解C言語 入門編 > 12. 構造体 >
ポインタのソート
Python
# coding: Shift_JIS NINSU = 5 def compare_height(x, y): if (x["height"] > y["height"]): return 1 if (x["height"] < y["height"]): return -1 return 0 def compare_weight(x, y): if (x["weight"] > y["weight"]): return 1 if (x["weight"] < y["weight"]): return -1 return 0 def sort(data, ptr, n, compare): k = n - 1 while (k >= 0): j = -1; for i in range(1, k + 1, 1): if (compare(data[ptr[i - 1]], data[ptr[i]]) > 0): j = i - 1 ptr[i], ptr[j] = ptr[j], ptr[i] k = j data = [] data.append({"name":"Sato", "height":178, "weight":61.0}) data.append({"name":"Sanaka", "height":175, "weight":60.5}) data.append({"name":"Takao", "height":173, "weight":80.0}) data.append({"name":"Mike", "height":165, "weight":72.0}) data.append({"name":"Masaki", "height":179, "weight":77.5}) ptr = [0, 1, 2, 3, 4]; print "ソート前:" i = 1 for d in data: print "%2d:%-8s%4d%6.1f" % (i, d["name"], d["height"], d["weight"]) i += 1 print sort(data, ptr, NINSU, compare_height) print "身長でソート後:" for i in range(0, NINSU, 1): print "%2d:%-8s%4d%6.1f" % (i + 1, data[ptr [i]]["name"], data[ptr [i]]["height"], data[ptr [i]]["weight"]) print sort(data, ptr, NINSU, compare_weight) print "体重でソート後:" for i in range(0, NINSU, 1): print "%2d:%-8s%4d%6.1f" % (i + 1, data[ptr [i]]["name"], data[ptr [i]]["height"], data[ptr [i]]["weight"]) print print "元の配列:" i = 1 def puts(data): global i print "%2d:%-8s%4d%6.1f" % (i, data["name"], data["height"], data["weight"]) i += 1 map((lambda d: puts(d)), data)
実行結果
N:\>python lesson_12_100.py
ソート前:
1:Sato 178 61.0
2:Sanaka 175 60.5
3:Takao 173 80.0
4:Mike 165 72.0
5:Masaki 179 77.5身長でソート後:
1:Mike 165 72.0
2:Takao 173 80.0
3:Sanaka 175 60.5
4:Sato 178 61.0
5:Masaki 179 77.5体重でソート後:
1:Sanaka 175 60.5
2:Sato 178 61.0
3:Mike 165 72.0
4:Masaki 179 77.5
5:Takao 173 80.0元の配列:
1:Sato 178 61.0
2:Sanaka 175 60.5
3:Takao 173 80.0
4:Mike 165 72.0
5:Masaki 179 77.5