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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ найти ошибку http://www.cyberforum.ru/cpp-beginners/thread186540.html
не выводит на экран arrsizetck, т.е как можно вывести число элементов в цикле?? int TCKf(char tcki, int tck, unsigned char *arrtck) { int arrsizetck; int i,c,j=0; ...
C++ Уплотнить матрицу. Что-то я намудрил.. Задание такое: Нужно уплотнить матрицу. Т.е. на убрать все 0-ли. Вместо их поставить следующий элемент если он есть. Вот код: (Только вот намудрил я что-то страшное) #include "stdafx.h"... http://www.cyberforum.ru/cpp-beginners/thread186534.html
C++ Нужна литература по теории графов
у меня курсовая работа идет на основе графов, а мы их не изучали, в теории которую дал препод все запутанно, смотрела в Google тож ничего конкретного, кто-нить может помочь? Помощь заключается в...
Как получить размер блока в файловой системе C++
Си+ linux. Пытаюсь вывести размер блока файловой системы struct stat buf; i = stat("имя файла", &buf); printf("Размер блока файловой системы - %u", buf.st_blksize); Но получаю странное...
C++ 1.1. Задания на строки http://www.cyberforum.ru/cpp-beginners/thread186480.html
никак не могу решить, помогите пожалуйста! 9.Вводится строка слов, разделенных пробелами (возможны лишние пробелы в начале и в конце строки и между словами). Сформировать строку, в которой удалены...
C++ массивы(заполнение и запись в файл) Подскажите с решением на с++ Пруд с водой. Предположим, что целая матрица - это пруд с водой. В любое место пруда бросают камешек. Место попадания обозначим цифрой 0. От камушка по воде расходятся... подробнее

Показать сообщение отдельно
Glacius
Сообщений: n/a
06.11.2010, 17:00
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;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru