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

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

Войти
Регистрация
Восстановить пароль
 
Soup_990
0 / 0 / 0
Регистрация: 16.11.2011
Сообщений: 34
#1

Определить значение первого положительного элемента динамического массива - C++

21.03.2012, 21:14. Просмотров 690. Ответов 1
Метки нет (Все метки)

С указателями недавно знаком, помогите решить. Код нужен на С.

Дан динамический целочисленный массив y1,y2,....,yn и динамическая символьная переменная h. Если значение h равно '+', преобразовать исходный массив к виду yn,yn-1,....,y2,y1. Иначе не менять порядок элементов.
Определить значения первого положительного элемента массива, освободить память от массива и записать номер этого элемента как динамическую переменную. Все исходные данные, результаты и соответствующие адреса памяти распечатать.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2012, 21:14     Определить значение первого положительного элемента динамического массива
Посмотрите здесь:

Определить номер первого положительного элемента массива и произведение следующих элементов - C++
Добуток елементив двовимирного масиву

Найти порядковый номер первого положительного элемента массива - C++
Необходимо найти порядковый номер первого положительного элемента одномерного массива с помощью 3 разных циклов.

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

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

Сумма элементов массива, расположенных после первого положительного элемента - C++
Помогите доделать последний пункт задачи, пожалуйста! Работаю в Visual Studio 2005, так уж заставили.. В интернете искал, но что-то...

Найти сумму элементов массива, расположенных после первого положительного элемента - C++
В общем есть задание: Найти сумму элементов массива, расположенных после первого положительного элемента. По моему код написан...

Найти сумму элементов массива, расположенных после первого положительного элемента - C++
Здравствуйте, помогите пожалуйста решить задачу на С++ Задание (непрерывные последовательности данных. Одномерные массивы). На языке...

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

Найти сумму элементов массива, расположенных после первого положительного элемента - C++
Помогите с лабораторной по массивам. Задание: 1. Исходные данные для всех вариантов - n вещественных величин. 2. При написании...

Найти сумму элементов массива, расположенных после первого положительного элемента - C++
Нужна помощь а решении задачи Найти сумму элементов массива, расположенных после первого положительного элемента #include...

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

Найти номер первого положительного элемента массива и сумму элементов правее него - C++
Найти номер первого положительного элемента массива b1,b2,b3,...,b10 и сумму элементов правее него. Вот мои наработки, сумма на 1 больше...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
soon
2540 / 1305 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
21.03.2012, 21:31     Определить значение первого положительного элемента динамического массива #2
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define SIZE 5
 
void swap(int* a, int* b)
{
    int c = *a;
    *a = *b;
    *b = c;
}
 
int main()
{
    srand(time(NULL));
    int* arr = (int*)malloc(SIZE * sizeof(int));
    int* positive = (int*)malloc(sizeof(int));
    char* c = (char*)malloc(sizeof(char));
    int i;
 
    for(i = 0; i < SIZE; ++i)
    {
        arr[i] = rand() % 21 - 10;
        printf("%d\t%p\n", arr[i], arr + i);
    }
 
    *c = ((rand() & 1) ? ('+') : ('-'));
 
    printf("\n%c\t%p\n\n", *c, c);
 
    if(*c == '+')
    {
        for(i = 0; i < SIZE / 2; ++i)
            swap(arr + i, arr + SIZE - i - 1);
        for(i = 0; i < SIZE; ++i)
            printf("%d\t%p\n", arr[i] , arr + i);
    }
 
    free(c);
 
    printf("\n");
 
    *positive = 0;
    for(i = 0; i < SIZE; ++i)
        if(arr[i] > 0)
        {
            *positive = arr[i];
            break;
        }
 
    free(arr);
 
    printf("%d\t%p\n", *positive, positive);
 
    free(positive);
 
    return 0;
}
Случай, когда нет положительного элемента сами обработаете.
Ответ Создать тему
Опции темы

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