Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Центр помощи > [C++] Одномерный динамический массив


Автор: pulsonq 22.3.2010, 14:28
Суть такова: создаётся одномерный динамич. массив целых чисел. Нужно пройти по этому массиву и все элементы, которые находятся между первым и вторым нулём переписать в новый динамич. одномерный массив. Размер нового массива = кол-ву элементов между нулями.

все выходные просидел, так толком ничего и не придумал smile .

Я буду ###, как благодарен Вам, если Вы мне поможите.

Создание и вывод массива я сделал, соответственно в кейс 1 и кейс 2. 
Код

// lab_18.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <iostream>
#include <ctime>
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
    int action;
    int *pointermass = NULL, *newpointermass = NULL;
    int size;
    int f=0;
    int diapazon,minnum;
    unsigned int r;    

    do
    {
        cout<<"\n1 - Create and initialize massive\n";
        cout<<"2 - Show massive\n";
        cout<<"3 - Action\n";
        cout<<"0 - Close programm\n";
        
        cout<<endl;
        cin>>action;
        cin.get();

        switch (action)
        {
            
           case 1:

                        cout<<"\ncreating and initializing massive\n";
                        cout<<"size of massive=?";
                        cin>>size;
                        cin.get();
                        if (pointermass != NULL)
                            delete [] pointermass;
                        pointermass = new int[size];
                        r=time(NULL)%32767;
                        srand(r);
                        cout<<"diapazon=?";
                        cin>>diapazon;
                        cin.get();
                        cout<<"min. number=?";
                        cin>>minnum;
                        cin.get();
                        
                // инициализация исходного массива
                  for(int i=0;i<size;i++)
                    *(pointermass+i)=(int)rand()/32767.0*diapazon+minnum;
                        

                        cout<<'\n';
                        break;

                case 2:
                if (pointermass == NULL)
                    cout<<"\nMassive is not created\n";
                else
                {
                    cout<<"\nMassive\n";
                    for(int i=0;i<size;i++)
                    cout<<(pointermass+i)<<'\t'<<*(pointermass+i)<<'\n';
                    cin.get();
                }
                
            break;

                            
        case 3:    
                
           case 0:
                        if (pointermass != NULL)
                            delete [] pointermass;

                    break;
                    
                    default:
                        cout<<"Very much!\n";
                        cin.get();

                }

                
            }while(action != 0);
    return 0;
}


Автор: azesmcar 22.3.2010, 14:35
Цитата(pulsonq @  22.3.2010,  14:28 Найти цитируемый пост)
Суть такова: создаётся одномерный динамич. массив целых чисел. Нужно пройти по этому массиву и все элементы, которые находятся между первым и вторым налём переписать в новый динамич. одномерный массив. Размер нового массива = кол-ву элементов между нулями.

Ну и в чем проблема? 1 раз прошелся, подсчитал количество элементов, нашел позиции первого и последнего нуля, второй раз прошелся по сохраненным позициям и заполнил массив.

Автор: EvilsInterrupt 22.3.2010, 14:35
1)
>>первым и вторым налём
что такое "наль" ?
2)
Где твой код, который ты пытался заставить работать?

ЗЫ:
Не хочешь быть девелопером, лучше уходи сразу!!! Не стоит тратить время тех, кто ничего тебе не обязан, а старается помочь тебе стать программистом!

Автор: pulsonq 22.3.2010, 14:40
что такое "наль" ?

исправил.
----
тот код, который я пытался заставить работать уже стёрт другим, а тот еще одним и т.д.

Автор: azesmcar 22.3.2010, 14:47
pulsonq

Если хочешь чтобы за тебя написали - тогда тебе в другой раздел. Попроси модераторов перенести в Центр Помощи.

Автор: pulsonq 22.3.2010, 16:56
Цитата(azesmcar @  22.3.2010,  14:47 Найти цитируемый пост)
pulsonq

Если хочешь чтобы за тебя написали - тогда тебе в другой раздел. Попроси модераторов перенести в Центр Помощи.


спасибо за инфо.

Автор: MAKCim 22.3.2010, 18:40
Для домашних заданий, курсовых, существует "Центр Помощи".

Тема перенесена! 

Автор: ИванМ 22.3.2010, 19:03
Код

#include <iostream>
#include <ctime>

int *array, *new_array;

int main()
{
    using namespace std;    
    srand((unsigned)time(NULL));
    cout<<"Enter the length of array: ";
    int size;
    cin>>size;
    array=new int[size];
    for(int i=0;i<size;i++)
        array[i]=rand()%5;
    for(int    i=0;i<size;i++)
        cout<<array[i]<<" ";
    cout<<endl;
    int from=-1, to=size-1;
    for(int i=0;i<size;i++)
    {
        if(!array[i])
        {
            if(from==-1)
                from=i+1;
            else
            {
                to=i-1;
                break;
            }
        }
    }
    if(from!=-1)
    {
        new_array=new int[to-from+1];
        for(int i=from;i<=to;i++)
        {
            new_array[i-from]=array[i];
        }
        cout<<"New array:"<<endl;
        for(int    i=0;i<to-from+1;i++)
            cout<<new_array[i]<<" ";
        cout<<endl;
    }    
    system("pause");
}


Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)