Модераторы: bsa
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Замена повторяющихся элементов массива сдвигом! 
:(
    Опции темы
Baton2007
Дата 15.12.2010, 23:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 117
Регистрация: 29.11.2007

Репутация: нет
Всего: нет



Читаю значение из командной строки в массив. Массив получается не до конца заполнен, нужно проверить не дублируются ли введенные элементы.
Сделал код , но что-то не работает .
Код

// заполнение массива пользователем
    for(i=0; i<27; i++) 
    {     char c= getchar();    
           if (c != '\n')
           {
           tempArray[i]=c;
           }
           else{break;}
           
        
    }
    granSlov=i;


    // проверка совпадений
    
      for(int k=1; k<i; k++) 
    {
        if(tempArray[k]!=tempArray[0])     // если символ не равен маркеру
                {
                  for (int j=k+1; j<i; j++)  // перебор от следующего за рассмотр. символом
                       if(tempArray[k]==tempArray[j]) 
                  {
                           tempArray[j-1]=tempArray[j];
                      k--;
                     }
                }
  }

А должен быть массив из не повторяющихся символов введенных пользователем , а после добитый нулями до размера 27. Мне нужно проверить на совпадения только те символы которые ввел пользователь.
Пользователь вводит: ABADC
Должно получиться:ABDC000000000000...
PM MAIL   Вверх
mes
Дата 15.12.2010, 23:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 79
Всего: 250



сортируете, и все повторения станут в ряд..
после копируете массив (можно в себя же), но только те элементы, у которых предыдущий сосед не равен им smile


--------------------
PM MAIL WWW   Вверх
Dov
Дата 16.12.2010, 00:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 11
Всего: 88



Код
int main()
{
    const int size      = 28;
    char      arr[size] = "";
    int       s[255]    = {0};
    int       i         = 0;
    int       ch;
    
    while(i < size - 1 && (ch = getchar()) != '\n')
        if(!s[ch]++)
            arr[i++] = ch;

    while(i < size - 1)
        arr[i++] = '0';

    cout << arr << endl;
    return 0;
}





--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Baton2007
Дата 16.12.2010, 07:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 117
Регистрация: 29.11.2007

Репутация: нет
Всего: нет



Ок спасибо все гениальное просто!!!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Для новичков"
JackYF
bsa

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0697 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.