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

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]. Освободившиеся в конце массива элементы заполнить нулями - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Фигуры, которые разбивают плоскость на области http://www.cyberforum.ru/cpp-beginners/thread846527.html
Здравствуйте! Суть: Даны фигуры, которые разбивают плоскость на области: трапеция с вершинами в точках: (0.5 , 0.5), (0.5 , 2.5), (4.5 , 2.5), (2.5 , 0.5), окружность с центром в точке (2,2) и радиусом r=1, и парабола с вершиной в точке (2,2), пересекающая ось Ox в точках (0,0) и (4,0). Составить алгоритм, который определяет, в какую из имеющихся на плоскости областей попадает...
C++ Монте-карло Преподаватель попросил разобрать метод монте-карло, и реализовать его в c++, помогите реализовать метод в с++ http://www.cyberforum.ru/cpp-beginners/thread846503.html
C++ Работа с srand и установка начального значения генератора чисел
Вообщем имеется вот такая строчка кода: srand( static_cast<unsigned int>(time(NULL)) ); Пишу в Borland C, но при компиляции выводит ошибку "Undefined symbol static_cast" Посоветуйте, что делать в таком случае??
Разработать класс индикатор времени C++
Помогите пожалуйста. Разработать класс индикатор времени, для которого устанавливается время, на протяжении которого он действует. Все объекты этого класса должны в зависимости от желания пользователя синхронно показывать или время своего создания, или время, прошедшее со времени создания, или время, оставшееся до конца жизни индикатора. После прекращения времени действия индикатор...
C++ не могу понять в чем ошибка http://www.cyberforum.ru/cpp-beginners/thread846470.html
Задание: Найти наибольший элемент каждой пары из массива А и записать их в новый массив. Получить из него массив четных положительных чисел Вот что у меня получилось: #pragma argsused #include<iostream.h> int main(int argc, char* argv) {int a, i, b,k; for(int i=0; i<10; i++) {cout<<"Vvedite element"; cin>>a; }
C++ Передвижение по строчке Проблема такова: есть строчка: char* text = "text1 text2"; Я ищу первый пробел: char* ch; ch = strchr(text, ' '); Потом обрезаю оставшиеся пробелы, чтобы остался только нормальный тест: if(ch!=NULL) { подробнее

Показать сообщение отдельно
Warezovvv
9 / 9 / 2
Регистрация: 09.12.2012
Сообщений: 219
25.04.2013, 00:06  [ТС]
С 37 до 43 строки я гуглил и гуглил, написал бред и пошел спать. Думаю тут фором нацти посл положительный и while найти сумму до последнего положительного. Про поиск посл положительного пока в голове мало идей

Добавлено через 666 часов 666 минут
Координально переписал. Вылетает Предупреждение неинициализированная локальная переменная "maxpoli".
хэлп хэлп?!

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
#include <iostream>
using namespace std;
int n,A,B;
 
void vvodmassiva(int n, int * mas);
void summadomaxpoli(int a,int * mas,int masxpoli);
void pokazat(int n, int * mas);
void szhatie(int n, int * mas, int A, int B);
void maximel(int n, int * mas,int maxpoli);
 
    void main(){
        int *mas = new int[n];
        int  max = mas[0];
        setlocale(LC_ALL,"rus");
        int a=0,b=1,maxpoli,A,B;
        cout<<"Введите размер массива= ";
        cin>>n;
    system("cls");
    vvodmassiva(n,mas);
    system("cls");
    pokazat(n,mas);
    maximel(n,mas,maxpoli);
    cout<<"Максимальный элемент массива= ["<<max<<"]"<<endl;
    summadomaxpoli(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();
    
 
        ;}
 
void vvodmassiva(int n, int * mas)             //Ввод массива
{
    cout<<"Введите элементы массива \r\n";
    int b=1;
    for(int i = 0; i < n; i++){
        cout<<"Элемент №"<<b++<<"= "; cin>>mas[i];}
}
 
void maximel(int n,int * mas,int maxpoli){     //Поиск максимального положительного
    int  max = mas[0];
    for (int i = 0; i < n; i++) {            
                  if (mas[i] >= max){
                  max = mas[i];
                  maxpoli=i;
                  }
            }
}
void pokazat(int n, int * mas)                 //Функция вывода массива
{
    for(int i = 0; i < n; i++)
        cout<<"Массив["<<i<<"]"<<mas[i]<<"\r\n";
    cout<<"\r\n";
}
 
void summadomaxpoli(int a,int * mas,int maxpoli){    //Сумма до максимального положительного
    for(int i=0;i<maxpoli;i++){                    
                a +=mas[i];
    }}
 
void szhatie(int n, int * mas, int A, int B)         //Сжатие массива
{
    cout<<"Szhatie massiva\r\n";
    for(int i = 0,j; i < n; i++)
    {
        if (A <= abs(mas[i]) && abs(mas[i])<=B) 
        {
            for(j = i; j < n - 1; j++)
                mas[j] = mas[j + 1];
            mas[j] = 0;
        }
    }
 
}
Добавлено через 34 минуты
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
    #include <iostream>
    #include <windows.h>
    using namespace std;
 
    int main(){
        setlocale(LC_ALL,"rus");
        int n,a=0,b=1,maxpoli,A,B;
        cout<<"Введите размер массива= ";
        cin>>n;
        SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), (2 + (0 * 16)) );
    int *mas = new int[n];
    int  max = mas[0];
    cout<<"Введите поочередно каждый элемент массива:"<<endl;        //ввод поэтапно элементов массива
            for(int i = 0; i < n; i++){
                cout<<"№"<<b++<<"= ";
                cin>>mas[i]; 
             }
//--------------------------------------------------------------------------------
            system("cls");//Очистка экрана
             for(int i = 0; i < n; i++){
                 cout <<"Ваши введенные элементы массива = "<< mas[i] << endl;
               }                     
            for (int i = 0; i < n; ++i) {            //Нахождение максимального элемента массива
                  if (mas[i] >= max){
                  max = mas[i];
                  maxpoli=i;
                  }
            }
            cout<<"Максимальный элемент массива= ["<<max<<"]"<<endl;
//-------------------------------------------------------------------------------           
            for(int i=0;i<maxpoli;i++){                    //Нахождение суммы всех элементов массивa
                a +=mas[i];
            }
    cout<<"Сумма всех элементов массива до последнего положительного = ["<<a<<"]"<<endl;
    cout<<"Введите A ";cin>>A;
    cout<<"Введите B ";cin>>B;
    for(int i = 0,j; i < n; i++)
    {
        if (a <= abs(mas[i]) && abs(mas[i])<=b) 
        {
            for(j = i; j < n - 1; j++)
                mas[j] = mas[j + 1];
            mas[j] = 0;
        }
    }
 
    for(int i = 0; i < n; i++)
        cout<<"Массив ["<<i<<"]"<<mas[i]<<"\r\n";
    cout<<"\r\n";
    return 0
        ;}
оригинал
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru