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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Как вывести переменную вещественного типа в графике? http://www.cyberforum.ru/cpp-beginners/thread587477.html
всем доброго времени суток)) дописываю курсовую калькулятор . результат вычисления записывается в переменную типа Double... А теперь собственно вопрос -как её на экран вывести?
C++ Задача про кузнечиков Даны n последовательных столбиков. Кузнечик находится на первом столбе, умеет прыгать на 1,2,...,k столбиков. Найти количество вариантов, которым он может допрыгать до n-го столба. Я знаю что решается динамическим программированием, пытался сам в нём разобрать, но не получилось. Мне нужен код на Pascal или C++, желательно с подробным объяснением. http://www.cyberforum.ru/cpp-beginners/thread587464.html
Оптимизация программы C++
Здравствуйте, получил я задание написать программу перемножения двух больших чисел, используя быстрое преобразование Фурье. Дал мне преподаватель на это 4 дня, чему я очень удивился - маловато будет, да и к тому же зачетная неделя. Ну да ладно, нашел пару статей - худо-бедно написал. Прихожу сегодня сдавать, получаю ответ такой, что мол фуфло все, давай оптимизируй, мол, ускорь процесс. Вобщем...
Разнообраный ввод даты C++
Как устроить разнообразный ввод даты? Например: 03.08.1994 или 3.8.94. Не обязательно через точку, как угодно.
C++ как занести значения в vector из файла и сохранить их в файл? http://www.cyberforum.ru/cpp-beginners/thread587460.html
Требуется написать класс для работы с текстовым файлом - проверка его состояния, позиция курсора, размер и т.д. С горем пополам наваял. Но вот условие задачи: "На основе разработанного класса разработайте приложение, выполняющее считывание входного текстового файла в память (для выделения массива данных нужного размера используйте класс vector), реверсирование массива символов, считанных из...
C++ Оптимизация программы Извиняюсь, тема создана ошибочно, прошу модератора удалить подробнее

Показать сообщение отдельно
SEV7
0 / 0 / 0
Регистрация: 29.11.2011
Сообщений: 34
26.05.2012, 17:49     Упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все ос
Упорядочить в каждой строке элементы массива, расположенные между первым и последним элементами, значения которых равны нулю, сместив в конец все остальные;

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

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

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

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();
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru