👤

Se consideră un text cu cel mult 100 de caractere, în care cuvintele sunt formate numai din litere mici ale alfabetului englez și sunt separate prin câte un spațiu. Scrieţi un program C++ care citeşte de la tastatură un text de tipul menţionat mai sus şi determină transformarea acestuia în memorie, astfel încât din fiecare cuvânt format dintr-un număr impar de litere (cel puțin trei) să se elimine litera aflată pe poziția din mijloc, ca în exemplu. Programul afişează pe ecran textul obţinut, iar dacă nu există niciun cuvânt modificat, afișează pe ecran mesajul nu exista.
Exemplu: pentru textu pictura prin aceea arata o pace profunda
se afişează picura prin acea arta o pace profunda
[folosind biblioteca <iostream> :D ]
help ...


Răspuns :

//#include <bits/stdc++.h>
#include <iostream>
#include <cstring>
#include <cstdlib>
using namespace std;
int n, i, k;
char s[105], t[105], aux[55], *p, *q;
bool ok;
int main()
{
    cin.getline(s, sizeof(s));
    ok = true;
    for(i = 0; i < strlen(s); ++ i)
    {
        if(s[i] != ' ') k ++;
        else
        {
            if(k % 2 && k >= 3)
                ok = false;
            k = 0;
        }
    }
    if(k % 2 && k >= 3)
        ok = false;
    if(ok)
    {
        cout << "nu exista";
        exit(0);
    }
    p = strtok(s, " ");
    while(p != NULL)
    {
        strcpy(t, p);
        n = strlen(t);
        if(n % 2 && n >= 3)
        {
            strcpy(t + n/2, t + n/2 + 1);
            cout << t << " ";
        }
        else
        cout << t << " ";
        p = strtok(NULL, " ");
        memset(t, 0, sizeof(t));
        memset(aux, 0, sizeof(aux));
    }
    return 0;
}