Форум программистов, компьютерный форум CyberForum.ru

Подскажите, как сделать сдвиг массива вправо для вставки нового элемента? - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.60
Sasha77777
0 / 0 / 0
Регистрация: 31.07.2012
Сообщений: 6
31.07.2012, 21:13     Подскажите, как сделать сдвиг массива вправо для вставки нового элемента? #1
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//  После каждого четного числа добавить число 0.
 
 
const int n=10;
int ar[n*2],k=n,t;
for(int i=0;i<n;i++){
    ar[i]=rand()%10+1;
    cout<<ar[i]<<"\t";
}
cout<<endl<<endl;
for(int i=0;i<k;i++){
    if(ar[i]%2==0){
        k++;// Увеличиваем кол-во
        for(int j=i+1;j<k;j++){  // Пытаюсь сделать сдвиг
            ar[j+1]=ar[j];
        }
        ar[i+1]=0;// Вставка нового элемента    
         i++;  // Обход нового элемента
    }
}
for(int i=0;i<k;i++){
    cout<<ar[i]<<"\t";
}
cout<<endl;
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.07.2012, 21:13     Подскажите, как сделать сдвиг массива вправо для вставки нового элемента?
Посмотрите здесь:

круговой сдвиг массива вправо C++
C++ Дан массив размера N. Осуществить циклический сдвиг элементов массива вправо на k позиций, где k- индекс максимального элемента.
C++ Сдвиг элементов массива вправо на ону позицию
Циклический сдвиг массива влево и вправо C++
Сдвиг элементов массива вправо и смена местами первого и последнего элемента C++
C++ Сдвиг элементов массива циклически на a позиций вправо
Дан массив размера N. Осуществить циклический сдвиг элементов массива вправо на k позиций, где k – индекс максимального элемента C++
Осуществить циклический сдвиг массива вправо на m позиций C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OhMyGodSoLong
~ Эврика! ~
 Аватар для OhMyGodSoLong
1234 / 983 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
31.07.2012, 21:48     Подскажите, как сделать сдвиг массива вправо для вставки нового элемента? #2
Типичная ошибка ;) Смотрите внимательно
C++
1
2
3
for(int j=i+1;j<k;j++){  // Пытаюсь сделать сдвиг
    ar[j+1]=ar[j];
}
Вот массив, сверху индексы, под ними данные, ещё ниже указатель на текущий элемент в цикле (указываемый j):
Код
... i i+1 i+2 ...
... 1  2   3  ...
    ^
Теперь мы выполняем ar[j + 1] = ar[j]:
Код
... i i+1 i+2 ...
... 1  1   3  ...
    ^
Сдвигаемся вперёд:
Код
... i i+1 i+2 ...
... 1  1   3  ...
       ^
Всё это безобразие повторяется в цикле. В итоге мы не сдвигаем массив, а делаем чёрти что, копируя один элемент на весь массив.

Правильно сдвигать надо с другой стороны. Так мы не перезаписываем нужные значения:
C++
1
2
3
for(int j = k - 1; j > i; j--){
    ar[j]=ar[j - 1];
}
Yandex
Объявления
31.07.2012, 21:48     Подскажите, как сделать сдвиг массива вправо для вставки нового элемента?
Ответ Создать тему
Опции темы

Текущее время: 01:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru