3157 - cifre c1c2

From Bitnami MediaWiki
Revision as of 19:34, 3 June 2024 by Benzar Ioan (talk | contribs) (Pagină nouă: == Cerința == Se citesc două cifre diferite c1 și c2 (nenule). Afișați în ordine crescătoare toate numerele care conțin exact c1 cifre egale cu c2 și c2 cifre egale cu c1. == Date de intrare == Programul citește de la tastatură cifrele c1 și c2 separate printr-un spațiu. == Date de ieșire == Programul va afișa pe ecran numerele cerute, câte unul pe un rând. == Restricții și precizări == *1 ≤ c1, c2 ≤ 9 *c1 ≠ c2 == Exemplu 1 == ;Intrare 2 3 ;Iesire 22...)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Cerința[edit | edit source]

Se citesc două cifre diferite c1 și c2 (nenule). Afișați în ordine crescătoare toate numerele care conțin exact c1 cifre egale cu c2 și c2 cifre egale cu c1.

Date de intrare[edit | edit source]

Programul citește de la tastatură cifrele c1 și c2 separate printr-un spațiu.

Date de ieșire[edit | edit source]

Programul va afișa pe ecran numerele cerute, câte unul pe un rând.

Restricții și precizări[edit | edit source]

  • 1 ≤ c1, c2 ≤ 9
  • c1 ≠ c2

Exemplu 1[edit | edit source]

Intrare

2 3

Iesire

22233
22323
22332
23223
23232
23322
32223
32232
32322
33222

Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line> def generate_numbers(c1, c2):

   from itertools import permutations
   c1 = str(c1)
   c2 = str(c2)
   digits = c1 * int(c2) + c2 * int(c1)
   permutations_set = set()
   for perm in permutations(digits):
       number = .join(perm)
       if number.count(c1) == int(c2) and number.count(c2) == int(c1):
           permutations_set.add(number)
   sorted_numbers = sorted(permutations_set)
   return sorted_numbers


def main():

   c1, c2 = map(int, input().strip().split())
   results = generate_numbers(c1, c2)
   for result in results:
       print(result)


if __name__ == "__main__":

   main()

</syntaxhighlight>