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

Массив - C++

Восстановить пароль Регистрация
 
dastin
Сообщений: n/a
28.05.2010, 15:31     Массив #1
Дан массив А(n) содержащий 2 нуля, посчитать сумму между 1 и 2 нулем, переписать массив удалив отрицательные элементы, полученный массив отсоритровать по убыванию. Помогите пожалуйста
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.05.2010, 15:31     Массив
Посмотрите здесь:

C++ Задан вектор X[20]. Положительные числа переписать в массив Y, а отрицательные в массив W
C++ Массив: Сформируйте массив C[n+m], состоящий из элементов массивов А и В, упорядоченный по возрастанию.
C++ Задан вектор X[20]. Положительные числа переписать в массив Y, а отрицательные в массив W
C++ задача записать в массив отрицательные элементы матрицы в массив и вывести их
Массив: Составить массив из двух исходных по заданному принципу заполнения C++
Массив: Переписать элементы одномерного массива A, попадающие в интервал [2, 6], в массив B. C++
Массивы и указатели (нужно передать массив I[10] в массив J[10] в обратной последовательности) C++
Как в массив скопировать массив, который заполнен через указатели C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
DenQ
Комбинатор
 Аватар для DenQ
978 / 244 / 6
Регистрация: 10.03.2010
Сообщений: 3,559
31.05.2010, 02:49     Массив #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
#include <iostream.h>
#include <conio.h>
using namespace std;
 
int main(){
    int mas[10] = {1, 2, -3, 0, 5, -6, -7, 0, 9, 7};
    int sum = 0;//сумма
    bool b = 0;//индикатор интервала [0-0]
    int c = 0;//счетчик отрицательных значений
    int k = 0;//разница в индексах массива - счетчик
//---Находим сумму элементов согласно условию------------------------
    for(int i = 0; i<10; i++){
        if(mas[i] == 0){
            if (b == 0) b = 1;
                else if(b==1) b=0;
        }
        if(b==1)
            sum+=mas[i];
    }
    cout << "Сумма: "<<sum<<"."<<endl;
//---Считаем кол.во отриц.элементов и создаем дополнительный.массив-- 
//---исходя из этих данных-------------------------------------------
    for(int i = 0; i<10; i++)
        if(mas[i]<0) c++;
    cout << c<<endl;//Необязательно. Кол.во отриц.элементов
    int *p;
    p = new int [10-c];
    for(int i = 0; i<10; i++)
        if (mas[i]>=0)
            p[i-k] = mas[i];
        else 
            if(mas[i]<0) k++;
//---Необязательно. Выводим новый массив, с удаленными отриц.элементами
    for(int i=0;i<(10-c);i++)
        cout << p[i]<<" ";
    cout << endl;
//---Сортируем новый массив методом пузырька :), согласно условию----
    int temp;
    for(int i=(10-c);i>0;i--)
        for(int j=(10-c)-1;j>0;j--)
            if(p[j]>p[j-1]){
                temp = p[j];
                p[j] = p[j-1];
                p[j-1] = temp;
            }
//---Необязательно. Выводим производный массив на печать-------------
    for(int i=0;i<(10-c);i++)
        cout << p[i]<<" ";
    cout << endl;
 
    delete p;
 
    getch();
    return 0;
}
Yandex
Объявления
31.05.2010, 02:49     Массив
Ответ Создать тему
Опции темы

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