2582 - Secv Elim: Difference between revisions

From Bitnami MediaWiki
Andrada378 (talk | contribs)
No edit summary
Andrada378 (talk | contribs)
No edit summary
Line 27: Line 27:
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python">
<syntaxhighlight lang="python">
s = input()
def elimina_duplicate_consecutive(s):
i = 0
    i = 0


while i < len(s) - 1:
    while i < len(s) - 1:
    if s[i].lower() == s[i + 1].lower():
        if s[i].lower() == s[i + 1].lower():
        c = s[i].lower()
            c = s[i].lower()
        j = i + 1
            j = i + 1
        while j < len(s) and s[j].lower() == c:
            while j < len(s) and s[j].lower() == c:
            j += 1
                j += 1
        s = s[:i] + s[j:]
            s = s[:i] + s[j:]
        i = -1
            i = -1
    i += 1
        i += 1


print(s)
    return s
input_str = input()
print(elimina_duplicate_consecutive(input_str))
</syntaxhighlight>
</syntaxhighlight>

Revision as of 12:12, 2 January 2024

Cerința

Se dă un șir de caractere care conține doar litere mici și mari ale alfabetului englez. Se parcurge șirul de la stânga la dreapta și dacă se întâlnește o secvență de litere alăturate egale, se șterge. Dacă în urma acestei operații se obține o nouă secvență de litere egale, se șterge și ea, ș. a. m. d.

Să se afișeze șirul obținut.

Date de intrare

Programul citește de la tastatură un șir de caractere.

Date de iesire

Programul va afișa pe ecran șirul obținut.

Restricții și precizări

  • șirul dat conține maximum 255 de caractere
  • nu se face diferență între literele mari și mici.

Exemplu

Intrare

aAcboOoBcAXa

Ieșire

AXa

Rezolvare

<syntaxhighlight lang="python"> def elimina_duplicate_consecutive(s):

   i = 0
   while i < len(s) - 1:
       if s[i].lower() == s[i + 1].lower():
           c = s[i].lower()
           j = i + 1
           while j < len(s) and s[j].lower() == c:
               j += 1
           s = s[:i] + s[j:]
           i = -1
       i += 1
   return s

input_str = input() print(elimina_duplicate_consecutive(input_str)) </syntaxhighlight>