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

Матрица динамическая. 1. максимальный элемент массива; 2. сумму элементов массива, расположенных до последнего положительного элемента - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ столкновения в box2d http://www.cyberforum.ru/cpp-beginners/thread875047.html
Добрый день, уважаемые форумчане. Продолжаю не легкий путь изучения с++. Столкнулся с забавной проблемой, есть мир на движке Box2d. Есть земля есть динамические объекты которые создаются по щелчку мыши и падают вниз на землю. Так вот при пересечении динамических объектов или при достижении любого объекта земли. Вылетает ошибка :Необработанное исключение в "0x001136bd" в "ТестовоеЗадание.exe":...
C++ разделение базы данных на две #include <stdio.h> #include <conio.h> #include <string.h> #include <windows.h> #include <iostream.h> #include <fstream.h> #define l "\n-------------------------------------------------------------------------------"; #define f "\nАбонент |Код | Адресат| Дата |Время | День |Длит. | Стоим. |Скидка |Сумма "; struct tdate { http://www.cyberforum.ru/cpp-beginners/thread875044.html
Определить количество М-значных натуральных чисел C++
Определить количество М-значных натуральных чисел,у которых сумма цифр, стоящих внечетных разрядах,равна N (1<=N<=30,0<М<5).
C++ Дано натуральное число .Если число содержит 5 цифр
Дано натуральное число N.Если число содержит 5 цифр,то получить новое число М,которое образуется путем исключения средней цифры исходного числа.Если количество цифр не 5,то M=N Пример.N=12345, М=1245.
C++ Дано натуральное число н(ен).Переставить местами первую и последнюю цифры этого числа http://www.cyberforum.ru/cpp-beginners/thread875029.html
Дано натуральное число н(ен).Переставить местами первую и последнюю цифры этого числа.
C++ Метод наименьших квадратов! (с Pascal на C++) Писал прогу на Паскале, так как не владею должными знаниями по С++ приходится просить помочь вас!!! Помогите перевести прогу написанную на Паскале в язык С++)) Пожалуйста!!! var i,j,k,n,m : integer ; A : array of real ; B,X,Y,P : array of real ; c,c1,F : real ; begin writeln('Введите размерность массива:'); read(n); подробнее

Показать сообщение отдельно
Warezovvv
 Аватар для Warezovvv
9 / 9 / 2
Регистрация: 09.12.2012
Сообщений: 219
29.05.2013, 05:05  [ТС]     Матрица динамическая. 1. максимальный элемент массива; 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
81
82
83
84
85
#include <iostream>
#include <windows.h>
 
using namespace std;
 
int vvodmassiva(int elements, int * mas);//Ввод массива +
void summadomaxpolozh(int a,int * mas,int& maxpol);//Сумма до максимального положительного
void pokazat(int elements, int * mas); //Функция вывода массива +
void szhatie(int elements, int * mas, int A, int B);//Сжатие массива
void maximel(int elements,int * mas,int maxpol,int maximal);//Поиск максимального положительного
 
    void main(){
        setlocale(LC_ALL,"rus");
        int n,a=0,b=1,maxpoli=0,A,B;
        system("cls");
        cout<<"Введите размер массива= ";
        cin>>n;
        SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), (2 + (0 * 16)) );
    int *mas = new int[n];
    int  max = mas[0];
    system("cls");
    vvodmassiva(n,mas);
    system("cls");
    pokazat(n,mas);
    maximel(n,mas,maxpoli,max);
    cout<<"Максимальный элемент массива= ["<<max<<"]"<<endl;
    summadomaxpolozh(a,mas,maxpoli);
    cout<<"Сумма всех элементов массива до последнего положительного = ["<<a<<"]"<<endl;
    cout<<"Введите A = ";cin>>A;
    cout<<"Введите B = ";cin>>B;
    szhatie(n,mas,A,B);
    cout<<"Хотите проверить еще один массив? Введите 1 если да. \r\n";
    cin>>n;
    if(n == 1)
        main();
        ;}
 
int vvodmassiva(int elements, int * mas)             //Ввод массива +
{
    cout<<"Введите элементы массива \r\n";
    int b=1;
     for(int i = 0; i < elements; i++){
        cout<<"Элемент №"<<b++<<"= "; cin>>mas[i];
     }
     return mas[elements];
}
 
int maximel(int elements,int * mas,int maxpol,int maximal){  //Поиск максимального положительного
    int  maximal = mas[0];                                                
    for (int i = 0; i < elements; i++) {            
                  if (mas[i] >= max){
                  maximal = mas[i];
                  maxpol=i;
                  }
        }
    return maximal;
}
 
void pokazat(int elements, int * mas)                 //Функция вывода массива +
{
    for(int i = 0; i < elements; i++)
        cout<<"Элемент массива ["<<i<<"] = "<<mas[i]<<"\r\n";
    cout<<"\r\n";
}
 
void summadomaxpolozh(int a,int * mas,int& maxpol){    //Сумма до максимального положительного
    for(int i=0;i<maxpol;i++){                    
                a +=mas[i];
    }
}
 
void szhatie(int elements, int * mas, int A, int B)            //Сжатие массива
{
    cout<<"Szhatie massiva\r\n";
    for(int i = 0,j; i < elements; i++)
    {
        if (A <= abs(mas[i]) && abs(mas[i])<=B) 
        {
            for(j = i; j < elements - 1; j++)
                mas[j] = mas[j + 1];
            mas[j] = 0;
        }
    }
 
}
мусор в максимальном положительном. помогите.

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