python3を使って
例えばa=[[2,5,6],
[3,7,8],
[1,4,9],
[11,10,12]]
という配列を
a=[[1, 2, 4],
[3, 5, 7],
[6, 8, 10],
[9, 11,12]]
というように行数 列数を変えずに斜めに並べ替える方法を教えてください。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答1件
0
ベストアンサー
自分で関数を作るしかないと思います。
試しに作ってみました。
もっとスマートに書けそうな気がします。
python
1""" 2>>> a=[[2,5,6], 3... [3,7,8], 4... [1,4,9], 5... [12,10,11]] 6>>> slash_sort(a) 7>>> print(a) 8[[1, 2, 4], [3, 5, 7], [6, 8, 10], [9, 11, 12]] 9>>> b=[[2,5,6], 10... [3,7,8], 11... [1,4,9]] 12>>> slash_sort(b) 13>>> print(b) 14[[1, 2, 4], [3, 5, 7], [6, 8, 9]] 15>>> c=[[2, 5, 6, 3, 7, 8], 16... [1, 4, 9, 12, 10, 11]] 17>>> slash_sort(c) 18>>> print(c) 19[[1, 2, 4, 6, 8, 10], [3, 5, 7, 9, 11, 12]] 20""" 21 22def slash_sort(a): 23 HEIGHT = len(a) 24 WIDTH = len(a[0]) 25 y = x = 0 26 for item in sorted(sum(a, [])): 27 a[y][x] = item 28 y, x = y + 1, x - 1 29 if x < 0: 30 y, x = max(0, y - WIDTH + 1), min(y, WIDTH - 1) 31 if y >= HEIGHT: 32 y, x = max(0, x + y + 1 - (WIDTH - 1)), min(x + y + 1, WIDTH - 1)
テスト結果
$ python3 -m doctest -v slashsort.py Trying: a=[[2,5,6], [3,7,8], [1,4,9], [12,10,11]] Expecting nothing ok Trying: slash_sort(a) Expecting nothing ok Trying: print(a) Expecting: [[1, 2, 4], [3, 5, 7], [6, 8, 10], [9, 11, 12]] ok Trying: b=[[2,5,6], [3,7,8], [1,4,9]] Expecting nothing ok Trying: slash_sort(b) Expecting nothing ok Trying: print(b) Expecting: [[1, 2, 4], [3, 5, 7], [6, 8, 9]] ok Trying: c=[[2, 5, 6, 3, 7, 8], [1, 4, 9, 12, 10, 11]] Expecting nothing ok Trying: slash_sort(c) Expecting nothing ok Trying: print(c) Expecting: [[1, 2, 4, 6, 8, 10], [3, 5, 7, 9, 11, 12]] ok 1 items had no tests: slashsort.slash_sort 1 items passed all tests: 9 tests in slashsort 9 tests in 2 items. 9 passed and 0 failed. Test passed.
投稿2019/11/30 07:13
総合スコア5406
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/11/30 08:05