Форум программистов, компьютерный форум 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; printf("arrtck ");
C++ Уплотнить матрицу. Что-то я намудрил.. Задание такое: Нужно уплотнить матрицу. Т.е. на убрать все 0-ли. Вместо их поставить следующий элемент если он есть. Вот код: (Только вот намудрил я что-то страшное) #include "stdafx.h" #include <stdio.h> #include <conio.h> int _tmain(int argc, _TCHAR* argv) { int n, m, i, j, mat, buf; http://www.cyberforum.ru/cpp-beginners/thread186534.html
C++ Нужна литература по теории графов
у меня курсовая работа идет на основе графов, а мы их не изучали, в теории которую дал препод все запутанно, смотрела в Google тож ничего конкретного, кто-нить может помочь? Помощь заключается в том что б дать какую нибудь ссылку на теорию где все расписано или простенькую прогу из которой элементарно было бы видно действия графов
Как получить размер блока в файловой системе C++
Си+ linux. Пытаюсь вывести размер блока файловой системы struct stat buf; i = stat("имя файла", &buf); printf("Размер блока файловой системы - %u", buf.st_blksize); Но получаю странное значение, типа - 131072. В чем может быть дело? Спасибо за любую ссылку или подсказку.
C++ 1.1. Задания на строки http://www.cyberforum.ru/cpp-beginners/thread186480.html
никак не могу решить, помогите пожалуйста! 9.Вводится строка слов, разделенных пробелами (возможны лишние пробелы в начале и в конце строки и между словами). Сформировать строку, в которой удалены лишние пробелы и повторявшиеся ранее слова. Порядок слов не менять.
C++ массивы(заполнение и запись в файл) Подскажите с решением на с++ Пруд с водой. Предположим, что целая матрица - это пруд с водой. В любое место пруда бросают камешек. Место попадания обозначим цифрой 0. От камушка по воде расходятся круги в виде цифр 1, 2, 3, ….. Написать программу для формирования поверхности пру-да после попадания камушка в любую точку пруда, т.е. матрицу А(m, n) заполнить следующим образом: для заданных k и... подробнее

Показать сообщение отдельно
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