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

интерактивный доступ к элементам списка в С++ - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Описать функцию PoslSu(t), которая выводит на печать последнюю строку непустого текстового файла http://www.cyberforum.ru/cpp-beginners/thread1033447.html
Описать функцию PoslSu(t), которая выводит на печать последнюю строку непустого текстового файла t (t-файловая переменная). Каким образом можно реализовать, напишите пожалуйста или алгоритм, или код. Спасибо.
C++ Ошибка при удалении явно заданного указателя Помогите, пожалуйста, с этой проблемой. Уже 2 недели не могу сдать лабу "main.cpp" char* a=new char; char b=0; char* c=new char; unsigned int d=0; int n; cout<<"Сколько будете вводить данных?"<<endl; n=ic(); //проверка на целое ant* inform=new ant; http://www.cyberforum.ru/cpp-beginners/thread1033443.html
Сортировка вставкой из Кормена C++
Видел тут пример сортировки вставкой, но он отличен от предложенного Корменом в книге "Алгоритмы. Построение и анализ. 3-е издание". Решил проверить его, а отладчик выдаёт ошибку. Подскажите в чём проблема. #include <stdio.h> #include <iostream> using namespace std; int main() { int A={19, 2, 5, 6, 8, 23, 0, 1, 5, 0}; cout<<"Old array "<<endl;
Вычисление значений рядных функций C++
Вычисление sin^2(x): \sin^2 x=e\times ({-1}^{n+1})\times (({2}^{2n+1}\times {x}^{2n})\div (2n)!)
C++ Нужно перевести на язык Pascal http://www.cyberforum.ru/cpp-beginners/thread1033409.html
Помогите перевести на язык Pascal, заранее благодарен! struct PRICE { char tovar; char mag; int cena; }; 32
C++ Незнакомые операторы Ребята, у меня есть программа, но нужно разобраться, что в ней за что отвечает... #include <conio.h> #include <iomanip.h> static struct zavod { struct zavod *p; char name; struct osn_sv { long int m3; struct kol_pr { подробнее

Показать сообщение отдельно
Ivan2812
0 / 0 / 0
Регистрация: 08.12.2013
Сообщений: 6
08.12.2013, 20:15  [ТС]     интерактивный доступ к элементам списка в С++
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#include "stdafx.h"
#include <stdlib.h>
#include <conio.h>
#include <iostream>
#include <list>
#include <ctime>
 
 
using namespace std;
class Massiv 
{
public:
    void Create(int *&Arr,const int N); //Метод выделения памяти под массив
    void Delete(int *&Arr); //Метод освобождения памяти
    void Fill(int *&Arr,const int N); //Метод заполнения массива значениями
    void Show(int *&Arr,const int N); //Метод отображения массива на экране
    void Perest(int *&Arr,const int N);
};
 
void Massiv::Create(int *&Arr,const int N)  //Вне класса описываем метод выделения памяти под массив
{
    for (int i=0;i<N;i++) Arr=new int[N];  
} 
 
void Massiv::Delete(int *&Arr) //Вне класса описываем метод освобождения памяти
{
    int *P=new int; //Выделяем резервный кусочек памяти
    P=NULL; //следуя правилам хорошего тона инициализируем его как пустой
    delete []Arr; //очищаем память от массива
    Arr=P; //указываем, что теперь массив должен находится в новом зарезервированном месте
}
 
 
void Massiv::Fill(int *&Arr,const int N)  //Вне класса определяем функцию заполнения массива
{
    for (int i=0;i<N;i++) Arr[i]=i; 
}
 
void Massiv::Show(int *&Arr,const int N) //определяем функцию отображения массива на экране
{
    for (int i=0;i<N;i++) cout<<Arr[i]<<"\t";
    cout<<endl; 
}
void Massiv::Perest(int *&Arr,const int N) //определяем функцию отображения массива на экране
{
    int k;
    int min=N;
    int i=N-1;
    int j=0;
    while(Arr[i]>Arr[i+1])
        --i;
    for(j=i+1;j<N;j++)
    {
        if(Arr[j]>Arr[i] & Arr[j]<=min) 
        {
            min=Arr[j];
            k=j;
        }
    }
    Arr[i]=Arr[i]+Arr[k];
    Arr[k]=Arr[i]-Arr[k];
    Arr[i]=Arr[i]-Arr[k];
    for (i=i+1,j=N-1;j>i;i++,j--)
    {   
        Arr[i]=Arr[i]+Arr[j];
        Arr[j]=Arr[i]-Arr[j];
        Arr[i]=Arr[i]-Arr[j];
    }
}
 
 
 
int main()
{
    int c=1;
    int i;
    int *Ptr=NULL; 
    Massiv Massiv; 
    int N=0; //количество элементов для массива
    cin>>N; //генерирую случайные числа
    Massiv.Create(Ptr,N); //выделяю память для N элементов
    Massiv.Fill(Ptr,N); //Записываю в каждый элемент значение
    
    Massiv.Show(Ptr,N); //Показываю массив на экране
    for(i=1;i<=N;i++)
        c=i*c;
    char stop ;
    for(i=1;i<c;i++)
    {
        list<int*>lst;
        lst.push_back(Ptr);
        //cout<<"size = "<<lst.size()<<endl;
        //cout<<"list before: \n";
        list<int*>::iterator p=lst.begin();
        while(p!=lst.end())
        {
            stop = getch();
            if(stop == 'n')
            {
            for(int j=0 ; j < N ; j++)
                cout<<(*p)[j]<<" ";
            cout<<endl;
            p++;
            }
            else if(stop=='b')
            {
                --p;
                /*for(int j=0 ; j < N ; j++)
                cout<<(*p)[j]<<" ";
                cout<<endl;*/
            }
        }
        Massiv.Perest(Ptr,N);
        //Massiv.Show(Ptr,N);
    }
    Massiv.Delete(Ptr); //Освобождаю память
    cout<<"\n\n";
    system("PAUSE");
    return 0;
}
почему-то не получается(((

Добавлено через 22 минуты
TwilightTwinkle, выводит элементы списка только в прямой последовательности. хелп!
 
Текущее время: 12:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru