Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
yevgesh
1 / 1 / 0
Регистрация: 26.08.2015
Сообщений: 30
Завершенные тесты: 1
1

Переворот массива с помощью указателей

25.09.2015, 21:21. Просмотров 880. Ответов 6
Метки нет (Все метки)

Здрасте! Учусь на программера недавно. Вот задали перевернуть массив рекурсивно с использованием указателей. На рекурсию я пока решил забить, так как и простой итерацией сделать это не могу. Код написал ниже. Вместо перевернутого массива выводится мусор. Заранее огромное спасибо за помощь!




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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include <iostream>
 
using namespace std;
 
int Reverse(int *pMas, int size1)
{
    int a = 0;
    for (int i = 0; i < size1; i++)
    {
        a = *(pMas + i);
        *(pMas + i) = *(pMas + size1 - i);
        *(pMas + size1 - i) = a;
    }
    for (int i = 0; i < size1; i++)
    {
        cout << *pMas << endl;
    }
    return 0;
}
 
void main()
{
    const int size1 = 5;
    int x = 0;
    int Mas[size1];
    int *pMas;
    pMas = Mas;
 
    for (int i = 0; i < 5; i++)
    {
        *pMas = x;
        x++;
        cout << *pMas << endl;
    }
 
    cout << endl << endl << endl;
 
    Reverse(pMas, size1);
 
    system("Pause");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.09.2015, 21:21
Ответы с готовыми решениями:

Варианты представления бинарного дерева с помощью массива и указателей
1 - Варианты представления бинарного дерева с помощью массива. 2 - Варианты...

Объеденить 2 одномерных массива в один с помощью указателей и функции
Очень нужна помощь.... С++ Массивы и указатели... 1) Объеденить 2 одномерных...

Вывести значения всех элементов одномерного массива с помощью указателей
Вывести значения всех элементов одномерного массива с помощью указателей, * в...

С помощью указателей найти наибольшую сумму непрерывной последовательности положительных чисел массива
помогите пожалуйста, что то не получилось у меня( Найти ту непрерывную...

Замените все четные значения введённого с клавиатуры массива нулями и вывести скорректированные значения (с помощью указателей)
Дорогие форумчане! Помогите пожалуйста с заданием!:cry: ...

6
Kerry_Jr
Эксперт PHP
2210 / 2006 / 940
Регистрация: 14.05.2014
Сообщений: 5,869
Записей в блоге: 1
Завершенные тесты: 5
25.09.2015, 21:27 2
Цитата Сообщение от yevgesh Посмотреть сообщение
C++
1
for (int i = 0; i < size1; i++)
вы его не переворачиваете. А точнее переворачиваете дважды - сначала как нужно, а потом обратно.
C++
1
for (int i = 0; i < size1/2; i++)
Добавлено через 2 минуты
Цитата Сообщение от yevgesh Посмотреть сообщение
C++
1
2
3
4
for (int i = 0; i < size1; i++)
{
    cout << *pMas << endl;
}
выводите одно и то же значение
C++
1
2
3
4
for (int i = 0; i < size1; i++)
{
    cout << *(pMas+i) << endl;
}
0
S_el
2151 / 1679 / 353
Регистрация: 15.12.2013
Сообщений: 6,644
25.09.2015, 21:28 3
yevgesh, давайте сразу с рекурсией разбираться.
Какие-то простые алгоритмы(задачи) рекурсивно решали?
0
Kerry_Jr
Эксперт PHP
2210 / 2006 / 940
Регистрация: 14.05.2014
Сообщений: 5,869
Записей в блоге: 1
Завершенные тесты: 5
25.09.2015, 21:31 4
Цитата Сообщение от yevgesh Посмотреть сообщение
C++
1
2
3
4
5
6
for (int i = 0; i < 5; i++)
{
    *pMas = x;
    x++;
    cout << *pMas << endl;
}
заполняете один и тот же элемент массива
C++
1
2
3
4
5
6
for (int i = 0; i < 5; i++)
{
    *(pMas+i) = x;
    x++;
    cout << *(pMas+i) << endl;
}
0
_Ivana
3233 / 1861 / 234
Регистрация: 01.03.2013
Сообщений: 5,091
Записей в блоге: 5
25.09.2015, 21:38 5
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
using namespace std;
 
int main() {
    auto rev = [] (int *b, int *e, const auto& la) -> int {
            if (b<=e) {int t=*b; *b=*e; *e=t; la(b+1,e-1,la);}};
    auto show = [] (int *b, int *e, const auto& la) -> int {
            if (b<=e) {cout<<*b<<'\t'; la(b+1,e,la);} else cout<<'\n';};
    int m[] = {1,2,3,4,5,6,7,8,9,10}, *e=m+sizeof(m)/sizeof(int)-1;
    show(m,e,show); rev(m,e,rev); show(m,e,show);
    return 0;
}
0
yevgesh
1 / 1 / 0
Регистрация: 26.08.2015
Сообщений: 30
Завершенные тесты: 1
25.09.2015, 22:07  [ТС] 6
Цитата Сообщение от S_el Посмотреть сообщение
yevgesh, давайте сразу с рекурсией разбираться.
Какие-то простые алгоритмы(задачи) рекурсивно решали?
Да. было дело. Класика - находил факториал числа.
0
daslex
1291 / 535 / 177
Регистрация: 02.08.2011
Сообщений: 2,756
25.09.2015, 22:36 7
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
 
using namespace std;
 
void reverse_arr(int *, int *);
 
void reverse_arr(int *ArrLeft, int *ArrRight){
    if (ArrRight<=ArrLeft) return;
    swap(*ArrLeft,*ArrRight);
    reverse_arr (ArrLeft+1,ArrRight-1);
}
 
int main()
{
    const int N=9;
 
   int Arr[N]={1,2,3,4,5,6,7,8,9};
   reverse_arr(Arr,Arr+N-1);
 
   for (int i=0;i<N;i++) cout<<Arr[i]<<"  ";
}
1
25.09.2015, 22:36
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.09.2015, 22:36

Переворот массива
Как переворачивают не обычных массив, а двухмерный ? К примеру 4x4 ?

Переворот массива
Как перевернуть массив на 180 градусов ? Помогите. Сам массив уже есть: ...

переворот двумерного массива на 90 градусов
Двумерный массив передать в функцию и перевернуть его на 90 градусов, результат...


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

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

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