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

Динамическая память - C++

Восстановить пароль Регистрация
 
logys
 Аватар для logys
0 / 0 / 0
Регистрация: 13.06.2011
Сообщений: 15
01.12.2012, 09:41     Динамическая память #1
Создать одномерный массив в котором хранятся года рождения людей (года вводятся в массив в ручную, размер массива не менее 5). Определить разницу в возрасте между самым старым человеком и самым молодым.


как я понял здесь используются функции выделяющие память (calloc и malloc),если не сложно помогите сделать этот динамический массив.

P.S. стаж изучения Си 3 месяца


заранее благодарю
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.12.2012, 09:41     Динамическая память
Посмотрите здесь:

C++ Динамическая память
Динамическая память C++
Динамическая память C++
C++ динамическая память....
Статическая память,Динамическая память. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11836 / 6815 / 770
Регистрация: 27.09.2012
Сообщений: 16,898
Записей в блоге: 2
Завершенные тесты: 1
01.12.2012, 11:32     Динамическая память #2
Может Вам в раздел С для начинающих?
Krugera
23 / 23 / 1
Регистрация: 14.11.2011
Сообщений: 112
01.12.2012, 15:52     Динамическая память #3
а обязательно использовать calloc и malloc?
Можно написать так:
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
#include "stdafx.h"
#include <iostream.h>
 
int main(int argc, char* argv[])
{
    int n=0;
    while(n<5){
    cout<<"vvedite kolichestvo dat";
    cin>>n;
    }
int *arr = new int [n];
for(int i=0;i<n;i++){
    
    cout<<"vvedite god rosgdeniy:";
    cin>>arr[i];
    while(arr[i]<1900||arr[i]>2012){
        cout<<"chiclo nevernoe,povtorite:";
    cin>>arr[i];
    }
    }
int xmax=0;
int xmin=0;
for(int a=0;a<n;a++){
    if(arr[xmax]<arr[n]){
        xmax=n;
    }
for(int j=0;j<n;j++){
    if(arr[xmin]>arr[j]){
        xmin=j;
    }
}
}
int g=arr[xmax]-arr[xmin];
cout<<g<<endl;
    return 0;
}
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
01.12.2012, 15:55     Динамическая память #4
Цитата Сообщение от Krugera Посмотреть сообщение
Можно написать так:
можно не значит нужно.
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
#include "stdafx.h"
#include <cstdio>
#include <cstdlib>
int main(int argc, char* argv[])
{
int xmax=0;
int xmin=0;
    int n=0;
    while(n<5){
    printf("vvedite kolichestvo dat");
    scanf("%d", &n);
    }
int *arr =(int*)malloc(n*sizeof(int));
for(int i=0;i<n;i++){
   printf("vvedite god rosgdeniy:");
    scanf("%d", arr+i);
    while(arr[i]<1900||arr[i]>2012){
        printf("chiclo nevernoe,povtorite:");
       scanf("%d", arr+i);
    }
    }
for(int a=0;a<n;a++){
    if(arr[xmax]<arr[n]){
        xmax=n;
    }
for(int j=0;j<n;j++){
    if(arr[xmin]>arr[j]){
        xmin=j;
    }
}
}
int g=arr[xmax]-arr[xmin];
printf("%d\n", g);
free(arr);
    return 0;
}
logys
 Аватар для logys
0 / 0 / 0
Регистрация: 13.06.2011
Сообщений: 15
01.12.2012, 18:37  [ТС]     Динамическая память #5
извиняюсь, что написал не там

Добавлено через 2 минуты
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
можно не значит нужно.
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
#include "stdafx.h"
#include <cstdio>
#include <cstdlib>
int main(int argc, char* argv[])
{
int xmax=0;
int xmin=0;
    int n=0;
    while(n<5){
    printf("vvedite kolichestvo dat");
    scanf("%d", &n);
    }
int *arr =(int*)malloc(n*sizeof(int));
for(int i=0;i<n;i++){
   printf("vvedite god rosgdeniy:");
    scanf("%d", arr+i);
    while(arr[i]<1900||arr[i]>2012){
        printf("chiclo nevernoe,povtorite:");
       scanf("%d", arr+i);
    }
    }
for(int a=0;a<n;a++){
    if(arr[xmax]<arr[n]){
        xmax=n;
    }
for(int j=0;j<n;j++){
    if(arr[xmin]>arr[j]){
        xmin=j;
    }
}
}
int g=arr[xmax]-arr[xmin];
printf("%d\n", g);
free(arr);
    return 0;
}
благодарю за помощь
Yandex
Объявления
01.12.2012, 18:37     Динамическая память
Ответ Создать тему
Опции темы

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