• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Generowanie permutacji z ograniczeniami

42 Warsaw Coding Academy
0 głosów
370 wizyt
pytanie zadane 8 stycznia 2017 w C i C++ przez Akdx Początkujący (310 p.)
Cześć, chciałem was zapytać jaki znacie najszybszy algorytm na generowanie permutacji z ograniczeniami (np. mamy liczby 1 6 2 9 3 i następujące pary {2,6}, {9,3}, {1,6} muszą być koło siebie). Da się inaczej niż po prostu wygenerować permutację i sprawdzić, czy jest poprawna? Czy można już na etapie ich tworzenia unikać niewłaściwych?
komentarz 8 stycznia 2017 przez niezalogowany
Czy chodzi o to, że dla jakiejś tablicy 1 6 2 mają być wypisane wszystkie różne ciągi 2-członowe: {1 6} {6 1} {6 2} {2 6} {1 2} {2 1} Nie jestem pewien czy "koło siebie" oznacza sposób wypisywania.
komentarz 8 stycznia 2017 przez Akdx Początkujący (310 p.)
No nie do końca, powiedzmy dla tej tablicy (1, 6, 2) mamy ograniczenie, że 6 i 2 mają być koło siebie, wówczas program powinien wygenerować wszystkie permutacje oprócz (6, 1, 2) i (2, 1, 6) - bo dla tych przypadków warunek o bliskości 2 i 6 nie jest spełniony. Właściwie zaczynam natrafiać na pewien trop - można by takie pary traktować jako pojedyncze elementy, aczkolwiek problem jest taki, że mogą też być trójki, czwórki, które muszą być koło siebie (wtedy ich kolejność między sobą jest dowolna, ale muszą tworzyć zwarty człon w permutacji), chociaż tutaj też można się pokusić o taką samą analogię... No tak to widzę póki co, może da się inaczej.

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 330 wizyt
0 głosów
1 odpowiedź 490 wizyt

93,389 zapytań

142,386 odpowiedzi

322,548 komentarzy

62,749 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

VMware Cloud PRO - przenieś swoją infrastrukturę IT do chmury
...