Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 40, средняя оценка - 4.70
Alecia
1 / 1 / 0
Регистрация: 28.11.2010
Сообщений: 29
#1

Реверс элементов массива - C++

28.11.2010, 18:10. Просмотров 6765. Ответов 6
Метки нет (Все метки)

Надо поменять значения элементов массива в обратном порядке.Первый->последний,второй->предпоследний и т.д.
Т.е.
mas[10]={2,3,5,8,9,0,3,4,5,7} должен измениться на
mas[10]={7,5,4,3,0,9,8,5,3,2}.

У меня же они зеркально отображаются.
mas[10]={9,8,5,3,2,2,3,5,8,9}.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.11.2010, 18:10
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Реверс элементов массива (C++):

Дан массив А. Образовать реверс массива А в массиве В. Вывести оба массива и индексы элементов на экран в виде трех столбцов. - C++
Дан массив А. Образовать реверс массива А в массиве В. Вывести оба массива и индексы элементов на экран в виде трех столбцов.

Выполнить реверс элементов массива отдельно в первой половине и во второй - C++
Массив имеет четное число элементов. Заполнить массив случайными числами и выполнить реверс отдельно в первой половине и второй половине. ...

Реверс массива - C++
Задание такое: Нужно сделать массив из 30 чисел, чтобы он отображался на экране наоборот и по 3 числа в столбик, при этом поменять столбики...

Реверс элементов в односвязанном списке за один проход - C++
Добрый день! Есть структура, представляющая из себя односвязный список. Как можно изменить порядок элементов на обратный в этом списке за...

Реверс цифр длинных чисел одномерного массива (итерация и рекурсия) - C++
Разработать функцию, которая переставляет в обратном порядке цифры заданного длинного целого числа (например, число 5321 превращается в...

Выполнить реверс отдельно в первой половине и второй половине массива - C++
Массив имеет четное число элементов,заполните массив случайными числами и выполнить реверс отдельно в первой половине и второй половине.

6
ForEveR
В астрале
Эксперт С++
7984 / 4743 / 321
Регистрация: 24.06.2010
Сообщений: 10,547
Завершенные тесты: 3
28.11.2010, 18:31 #2
Alecia, Если по простому.
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
25
26
27
#include <iostream>
 
int* rev(int* Arr, int n)
{
    int* Tmp=new int[n];
    for(int i=0, j=n-1; i<n; ++i, --j)
    {
        Tmp[i]=Arr[j];
    }
    return Tmp;
}
 
int main()
{
    int n;
    std::cout<<"Enter n: ";
    std::cin>>n;
    int* Arr=new int[n];
    for(int i=0; i<n; ++i)
        std::cin>>Arr[i];
    Arr=rev(Arr, n);
    for(int i=0; i<n; ++i)
        std::cout<<Arr[i]<<' ';
    std::cout<<'\n';
    delete[] Arr;
    return 0;
}
0
Alecia
1 / 1 / 0
Регистрация: 28.11.2010
Сообщений: 29
28.11.2010, 18:38  [ТС] #3
Вот мой код
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
25
26
27
#include <iostream>
using namespace std;
void revers (int mas, int sa);
int main()
 
{
const int sa=10;
int mas[sa]={5,6,7,8,9,1,2,3,4,0};
cout<<"Your massiv: "<<endl;
for (int i=0; i<sa; i++)
{cout<<mas[i]<<" ";}
cout<<endl<<endl;
revers(mas,sa);
return 0;
}
 
void revers (int mas, int sa)
{
for (int c=0; c<sa; c++)
{mas[c]=mas[sa-1];
sa--;
}
 
cout<<"New massiv: "<<endl;
for (с=0; с<sa; с++)
{cout<<mas[с]<<" ";}
}
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
28.11.2010, 18:49 #4
C
1
2
3
4
5
6
for (i=0,j=N-1;i<j;i++,j--)   // N dlina massiva
 // zamena
{ buf=ms[i];          
   ms[i]=ms[j];
   ms[j]=buf;
}


Добавлено через 1 минуты
Цитата Сообщение от Alecia Посмотреть сообщение
mas[c]=mas[sa-1];
у вас не правильная замена
надо использовать либо буффер (доп. переменную) либо математический с помощью сложения и вычитания, если без доп. переменной
вот замена с доп. переменной
C
1
2
3
4
{ buf=ms[i];          
   ms[i]=ms[j];
   ms[j]=buf;
}
1
Alecia
1 / 1 / 0
Регистрация: 28.11.2010
Сообщений: 29
28.11.2010, 18:58  [ТС] #5
Спасибки огромное! =)
Ошибку свою поняла!
Исправила!
Всё работает!
=)
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
28.11.2010, 19:02 #6
Alecia, вот замена без доп. переменной (может пригодится)
C
1
2
3
4
5
{
ms[i]=ms[i]+ms[j];
ms[j]=ms[i]-ms[j];
ms[i]=ms[i]-ms[j];
}
0
kazak
3051 / 2372 / 160
Регистрация: 11.03.2009
Сообщений: 5,437
Завершенные тесты: 1
29.11.2010, 04:24 #7
C++
1
2
3
4
5
for (int i = 0; i < size/2; i++){
   tmp = mas[i];
   mas[i] = mas[size-i-1];
   mas[size-i-1] = tmp;
}
0
29.11.2010, 04:24
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.11.2010, 04:24
Привет! Вот еще темы с ответами:

В одномерном массиве, состоящем из n вещественных элементов вычислить минимальный элемент массива и сумму элементов массива. [CPP] - C++
В одномерном массиве, состоящем из n вещественных элементов вычислить минимальный элемент массива и сумму элементов массива, расположенных...

Вычислить количество положительных элементов массива и сумму элементов массива, расположенных после последнего элемента, равного нулю - C++
В одномерном массиве, состоящем из n вещественных элементов, вычислить: количество положительных элементов массива; сумму элементов...

В одномерном массиве, состоящем из n целых элементов, 1) номер максимального элемента массива; 2) произведение элементов массива, расположенных между - C++
Помогите исправить программу Задание: В одномерном массиве, состоящем из n целых элементов, 1) номер максимального элемента...

Записать положительные элементы массива X подряд в массив Y. Определить k – количество положительных элементов. Вычислит сумму элементов массива Y - C++
Записать положительные элементы массива X=(x1,x2,…, xn) подряд в массив Y=(y1,y2,…, yk). Определить k – количество положительных...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.