Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/64: Рейтинг темы: голосов - 64, средняя оценка - 4.78
 Аватар для Warezovvv
9 / 9 / 3
Регистрация: 09.12.2012
Сообщений: 219

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

23.04.2013, 23:16. Показов 13642. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1. максимальный элемент массива;
2. сумму элементов массива, расположенных до последнего положительного элемента.
Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]. Освободившиеся в конце массива элементы заполнить нулями.
Вообщем вот задание.
Когда перечитал понял что сумма до последнего положительного. Начал все переписывать и в конце получается "ахинея".

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=0,a=0,b=1; 
        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];}
                   }
                cout<<"Максимальный элемент массива= ["<<max<<"]"<<endl;
            
 
    //-------------------------------------------------------------------------------
    int A,B;
    
cout<<"Введите A ( [A,B] ) = ";cin>>A;
cout<<"Введите B ( [A,B] ) = ";cin>>B;
    if (abs(mas[n]) >=A && abs(mas[n]) <=B)
    {
        for (int k=n;k<n-1;k++) mas[k]=mas[k+1];
        mas[n-1]=0;
        --n;
    }
    cout<<"Последний положительный "<<n<<endl;
    for(int i=0;i<n;i++){                    //Нахождение суммы всех элементов массивa
                    a +=mas[n];
                }
        cout<<"Сумма всех элементов массива = ["<<a<<"]"<<endl;
    for(int i=0;i<n;i++) cout<< mas[i]<<"";
    //-------------------------------------------------------------------------------
    return 0
        ;}
Добавлено через 28 минут
upppp

Добавлено через 3 часа 40 минут
uupuppuu
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.04.2013, 23:16
Ответы с готовыми решениями:

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

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

Сжать массив, удалив из него все элементы, модуль которых не превышает 1. Освободившиеся в конце массива элементы заполнить нулями
Сжать массив, удалив из него все элементы, модуль которых не превышает 1. Освободившиеся в конце массива элементы заполнить нулями. ...

2
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
24.04.2013, 03:06
Строка 37: при обращении к mas[n] получаете мусор, поскольку индексы в массиве от 0 до n-1.

Строка 39: как этот for заработает?
0
 Аватар для Warezovvv
9 / 9 / 3
Регистрация: 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
        ;}
оригинал
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.04.2013, 00:06
Помогаю со студенческими работами здесь

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

Сжать массив, удалив из него все элементы модуль которых не превышает 1. Заполнить эти элементы нулями
Во время перестановки, когда первый 0 достигает конца массива, выскакивает ошибка и прога останавливается. При этом на последнем элементе...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [а, b]
Указатели с++: Задача: В одномерном массиве , состоящем из n действительных элементов , вычислить : • максимальный элемент массива ; ...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале
В одномерном массиве, состоящем из п вещественных элементов, вычислить: Сжать массив, удалив из него все элементы, модуль которых...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b].
Дан одномерный массив А, состоящий из N целых чисел. Сжать массив, удалив из него все элементы, модуль которых находится в интервале ....


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru