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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
SEV7
0 / 0 / 0
Регистрация: 29.11.2011
Сообщений: 34
#1

Упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все ос - C++

26.05.2012, 17:49. Просмотров 266. Ответов 0
Метки нет (Все метки)

Упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все остальные;

Вычисление значения в каждом столбце суммы элементов, расположенных между первым и последним элементами, значения которых равны нулю;

Вывод в каждой строке элементов кратных пяти.

Подскажите как доделать, запарился уже, вот код.
Заранее спасибо всем, кто поможет.

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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include <iostream>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <iomanip>
#include <stdio.h>
#include <math.h>
using namespace std;
class process{
    private:
        int size;
        int *mass;
    public:
        process(){
            cout << "Put size: ";
            do{cin >> size;}while(size <= 0);
            mass = new int [size * size];
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    cout << "Put mass[" << i << "," << j << "]: "; cin >> *(mass + (i * size + j));
                };
            };
        };
        process(int size, int min = 0, int max = 0){
            this->size = size;
            mass = new int [size * size];
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    *(mass + (i * size + j)) = rand() / (1.0 * RAND_MAX) * (max - min) + min;
                };
            };
        };
        ~process(){delete(mass);};
 
        void out(){
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    cout << *(mass + (i * size + j)) << "\t";
                };
                cout << "\n\n";
            };
        };
        void sort(){
            int buf, buf1;
            int first, last;
            int i, j , q, k = 0;
            for(i = 0; i < size; i++){
                    for(j = 0; j < size; j++){
                        if(*(mass + (i * size + j)) != 0){
                            k = 1;
                        }
                        else{
                        while(*(mass + (i * size + j++)) != 0);
                        first = j;
                        while(*(mass + (i * size + j++)) != 0);
                        last = j - 2;
                        cout << i + 1 << " first: " << first << "\n"; //Здесь нахожу первый эелемент           расположенный между нулями
                        cout << i + 1 << " last: " << last << "\n"; //Здесь нахожу второй эелемент           расположенный между нулями. но вот как упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все остальные не могу реализовать.
                        };
                    };
            };
        };
 
        void krat(){
            int k = 0;
            for(int i = 0; i < size; i++){
                int kr = *(mass + (i * size + 0));
                for(int j = 1; j < size; j++){
                    if(kr % 5 != 0){k = 1;}else{kr = *(mass + (i * size + j));};
                };
                if (k == 1){cout << "No el / 5!!!" << "\n";}
                else{cout << i << ": Kratn 5 = " << kr << "\n";};
            };
        };
        void sum_i(){
            int sum = 0;
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    sum = sum + *(mass + (i / size * size + j));
                };
                cout << i << ": sum= " << sum << "\n";
            };
        };
        void operator! (){
            int u;
            cout << "Put u: "; cin >> u;
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    *(mass + (i * size + j)) -= u;
                };
            };
        };
        process operator* (process &p1){
            process buf(size);
            for(int i = 0; i < size; i++){
                for(int j = 0; j < size; j++){
                    *(buf.mass + (i * size + j)) = *(mass + (i * size + j)) - *(p1.mass + (i * size + j));
                };
            };
            return buf;
        };
};
int main(){
    srand( (unsigned) time(NULL));
    process p1;
    p1.out();
    cout << "-----------------------------------\n";
    p1.sort();
    p1.out();
    //cout << "-----------------------------------\n";
    //p1.krat();
    //cout << "-----------------------------------\n";
    //p1.sum_i();
    cout << "-----------------------------------\n";
    !p1;
    p1.out();
    cout << "-----------------------------------\n";
    process p2, p3;
    p2.out();
    cout << "-----------------------------------\n";
    p3.out();
    cout << "-----------------------------------\n";
    (p2 * p3).out();
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.05.2012, 17:49
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все ос (C++):

Массивы. Выписать в отдельный массив элементы, расположенные между первым и последним нулевыми элементами - C++
Выписать в отдельный массив элементы, расположенные между первым и последним нулевыми элементами исходного мас-сива. Если выполнить такую...

Дан массив D[0:n-1]. Удалить из него элементы, расположенные между первым и последним отрицательными элементами путём сдвига - C++
помогите пожалуйста. Нужен полный текст программы, заранее благодарен

Упорядочить по убыванию элементы массива между первым положительным и последним отрицательным - C++
Упорядочить в порядке убывания элементы массива, расположенные между первым положительным и последним отрицательным значениями массива

Упорядочить по убыванию элементы массива, стоящие между первым максимальным и последним минимальным - C++
Упорядочить по убыванию элементы массива, стоящие между первым максимальным и последним минимальным элементами.(массив целочисленный)

Перемножить элементы массива, расположенные между первым и вторым нулевыми элементами; найти максимальный - C++
В одномерном массиве, состоящем из N целых элементов, вычислить: - номер максимального элемента массива; - Умножение элементов массива,...

Добавить в конец массива элементы, расположенные между min и max элементами исходного массива, исключая нули - C++
добавить в конец массива элементы, расположенные между минимальными и максимальными элементами исходного массива, исключая нулевые

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.05.2012, 17:49
Привет! Вот еще темы с ответами:

Просуммировать все элементы массива, которые находятся между первым и последним нулем - C++
У меня такая задача: мне надо просуммировать все элементы массива, которые находятся между первым нулем в массиве и последним нулем. Для...

Удалить все элементы, расположенные между минимальным и максимальным элементами массива - C++
Дан линейный массив из n элементов. Удалить все элементы, расположенных между минимальным и максимальным элементами массива. Помогите...

Удалить все элементы массива расположенные между максимальным и минимальным элементами - C++
в целочисленном массиве X(N) удалить все элементы, расположенные между максимальным и минимальным элеметами. Найти средне арифметическое...

сумму элементов массива, расположенных между первым и последним отрицательными элементами - C++
4 В одномерном массиве, состоящем из 20 вещественных элементов, вычислить: сумму элементов массива, расположенных между первым и...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru