Виклик:
Подаючи список непорожніх списків цілих чисел, поверніть перелік кортежів такої форми: Перші списки кортезів, починаючи з кожного елемента першого списку, а потім першого елемента кожного наступного списку, таким чином, має бути й кортеж [ith element of first list, first element of second list, ... , first element of last list]. Наприклад:
[[1, 2, 3], [4, 5, 6], [7, 8, 9]] => [[1, 4, 7], [2, 4, 7], [3, 4, 7], ...
Потім виконайте кортежі форми [last element of first list, ith element of second list, first element of third list, ..., first element of last list], так що в нашому прикладі це було б:
[[1, 2, 3], [4, 5, 6], [7, 8, 9]] => ..., [3, 4, 7], [3, 5, 7], [3, 6, 7], ...
Продовжуйте продовжувати роботу з кожним залишковим списком, поки не досягнете [last element of first list, ..., last element of second to last list, ith element of last list]:
[[1, 2, 3], [4, 5, 6], [7, 8, 9]] => ..., [3, 6, 7], [3, 6, 8], [3, 6, 9]]
Повний вихід такий:
[[1, 2, 3], [4, 5, 6], [7, 8, 9]] =>
[[1, 4, 7], [2, 4, 7], [3, 4, 7], [3, 5, 7], [3, 6, 7], [3, 6, 8], [3, 6, 9]]
Деякі котельня для хорошої міри:
- Якщо ви хочете, щоб вхід був списками рядків або списками натуральних чисел, це добре. Питання полягає в маніпулюванні списками, а не в тому, що є у списках.
- Введення та вихід можуть бути у будь-якому прийнятному форматі .
- Дозволена або повна програма, або функція.
- Стандартні лазівки заборонені за замовчуванням.
- Це питання є кодовим гольфом, тому виграє найменший байт.
Приклади:
[] => [[]] (or an error, thanks to ngn for correcting the output in this case)
[[1]] => [[1]]
[[1, 2], [3, 4], [5]] => [[1, 3, 5], [2, 3, 5], [2, 4, 5]]
[[1], [2], [5, 6], [3], [4]] => [[1, 2, 5, 3, 4], [1, 2, 6, 3, 4]]
[[1, 2, 3], [4, 5]] => [[1, 4], [2, 4], [3, 4], [3, 5]]
[[1, 2, 3], []] => unspecified behavior (can be an error)
[[3, 13, 6], [9, 2, 4], [5, 10, 8], [12, 1, 11], [7, 14]] =>
[[3, 9, 5, 12, 7], [13, 9, 5, 12, 7], [6, 9, 5, 12, 7], [6, 2, 5, 12, 7],
[6, 4, 5, 12, 7], [6, 4, 10, 12, 7], [6, 4, 8, 12, 7], [6, 4, 8, 1, 7],
[6, 4, 8, 11, 7], [6, 4, 8, 11, 14]]
[[16, 8, 4, 14, 6, 7, 10, 15], [11, 1, 12, 2, 19, 18, 9, 3], [13, 5, 17]] =>
[[16, 11, 13], [8, 11, 13], [4, 11, 13], [14, 11, 13], [6, 11, 13],
[7, 11, 13], [10, 11, 13], [15, 11, 13], [15, 1, 13], [15, 12, 13], [15, 2, 13],
[15, 19, 13], [15, 18, 13], [15, 9, 13], [15, 3, 13], [15, 3, 5], [15, 3, 17]]
Якщо хтось має кращу назву, дайте мені знати.
[[]]тому що є один порожній кортеж з одним записом з кожного (нульового) списку. Напевно, це занадто прикро, щоб вимагати, щоб програми правильно виводили це, тому я скажу, що це не потрібно.
[], строго кажучи, порожній список не порожніх списків, але вихід неоднозначний між тим, []і [[]]якщо це дозволений ввід. ("Кортежі першого списку, починаючи з кожного елемента першого списку ..." - першого списку немає, тому ми закінчили -> [])
[]повинен бути [[]]. Наприклад, кількість вихідних кортежів - це те, sum(inner list lengths) - length of outer list + 1що в порожньому випадку дає 1, яке є довжиною, [[]]але не довжиною []. Це трохи педантичне питання, хоча ...
[] => []насправді повинно бути,[] => [[]]але не можу знайти слова, щоб пояснити, чому.