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

Исключить из массива первый, предшествующий максимуму, положительный элемент - C++

Восстановить пароль Регистрация
 
alena900
3 / 3 / 0
Регистрация: 13.10.2009
Сообщений: 78
05.11.2010, 12:06     Исключить из массива первый, предшествующий максимуму, положительный элемент #1
Дан одномерный массив А, состоящий из N элементов. Исключить из массива первый, предшествующий максимуму, положительный элемент.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.11.2010, 12:06     Исключить из массива первый, предшествующий максимуму, положительный элемент
Посмотрите здесь:

C++ Переставить в 1-м массиве первый отрицательный и последний положительный элемент местами
Заменять первый положительный элемент массива средним арфиметическим C++
C++ найти первый положительный элемент и записать данные в новый массив
Исключить из массива А(n) первый отрицательный элемент C++
C++ Первый отрицательный и последний положительный элемент читаемый из файла
C++ Для каждого столбца матрицы найти первый положительный элемент
Поменять местами первый отрицательный и последний положительный элемент массива C++
C++ Исключить из массива первый положительный элемент

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Glacius
Сообщений: n/a
06.11.2010, 17:00     Исключить из массива первый, предшествующий максимуму, положительный элемент #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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include "stdafx.h"
#include <iostream>
#include <windows.h>
#include <stdio.h>
#include <conio.h>
#include <time.h>
 
using namespace std;
 
//создаем и заполняем массив
int *init_vector(int n)
{
    srand(time(0)); 
    int *x = new int[n];
    for (int i=0; i<n; i++)
    {
        x[i] = rand()%101-50;
        cout << x[i]<< "\t";
    }
    return x;
}
 
bool max_elem(int *x, int n)
{
    int max = x[0];
    int *y = new int[n-1];
    int _index1=0, _index2=0;
    for (int i=0; i<n; i++) //ищем максимальный элемент
    {   
        if (max < x[i])
        {
            max = x[i];
            _index1 = i;
        }
    }
    cout << "Max element = " << max << endl;
    if (_index1 == 0) //если его нет или он первый - выходим
        return 0;
 
 
    for (int i=_index1; i>=0; i--)
    {
        if (x[i] < 0)
        {
            _index2 = i;
            break;
        }
    }
    if (_index2 == 0)
        return 0;
 
    for (int i=_index2; i<n-1; i++) //делаем циклическое смещение в массиве
    {
        x[i] = x[i+1];
    }
    memcpy(y, x, sizeof(x)*(n-1)); //копируем старый в новый, но с размером на 1 элем. меньше
 
    cout << "New vector:" << endl;
    for (int i=0; i<n-1; i++)
    {
        cout << y[i]<< "\t";
    }
    delete x;//освобождаем память
    delete y;
    return 1;
}
 
int main()
{
    int n, *f1;
    bool f2;
    cout << "Range vector:\n";
    cin >> n;
    f1 = init_vector(n);
    if (f2 = max_elem(f1, n) == 0) //напишет если перед макс. элементом все >0 или он 
        cout << "Try again"<<endl; //имеет индекс 0
    cout << endl;
    _getch();
    return 0;
}
Yandex
Объявления
06.11.2010, 17:00     Исключить из массива первый, предшествующий максимуму, положительный элемент
Ответ Создать тему
Опции темы

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