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

Заполнить массив убывающими элементами - C++

Восстановить пароль Регистрация
 
HelloWorld56
5 / 5 / 1
Регистрация: 29.03.2012
Сообщений: 62
19.05.2012, 17:04     Заполнить массив убывающими элементами #1
Например: 67 56 43 32 5 3

C++ (Qt)
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
#include <iostream>
#include <ctime>
using namespace std;
 
int main ()
{
    setlocale (LC_CTYPE, "Russian");
    srand(time(NULL));
 
    const int size = 25;
    int array1[size];
 
    for (int i = 0; i < size; i++)
    {
        array1[i] = 1 + rand() % 100;
        
        if (i > 0)
            if (array1[i] >= array1[i-1])
            {
                i--;
                 
            }
            
            
        
            
    }
    for (int i = 0; i < size; i++)
    {
        cout<<array1[i]<<" ";
    }
        
 
    
}
Ничего не выводит, просто чёрный экарн
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.05.2012, 17:04     Заполнить массив убывающими элементами
Посмотрите здесь:

C++ Вначале заполнить массив элементами с четными индексами, а затем - с нечетными.
Дан массив A[N]. заполнить массив В[N] элементами массива A[N], которые удовлетворяют двойному неравенству C++
C++ Заполнить массив неповторяющимися элементами
заполнить двумерный массив элементами в соответствии с рисунком C++
C++ Заполнить массив в структуре элементами другого массива
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
antoha398
155 / 155 / 3
Регистрация: 29.03.2012
Сообщений: 418
19.05.2012, 17:11     Заполнить массив убывающими элементами #2
а не проще заполнить случайными и отсортировать)

Добавлено через 3 минуты
Скорей всего у вас зацикливается на ваших условиях.
HelloWorld56
5 / 5 / 1
Регистрация: 29.03.2012
Сообщений: 62
19.05.2012, 17:11  [ТС]     Заполнить массив убывающими элементами #3
Цитата Сообщение от antoha398 Посмотреть сообщение
а не проще заполнить случайными и отсортировать)
отсортировать я могу, но нужно при вводе заполнить
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4919 / 2662 / 243
Регистрация: 29.11.2010
Сообщений: 7,399
19.05.2012, 17:35     Заполнить массив убывающими элементами #4
Программа зацикливается. Мб стоит заполнить массив, а потом уже его отсортировать по убыванию?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
#include <algorithm>
#include <ctime>
using namespace std;
 
int main ()
{
    setlocale (LC_CTYPE, "Russian");
    srand(time(NULL));
 
    const int size = 25;
    int array1[size];
 
    for (int i = 0; i < size; i++)
        array1[i] = 1 + rand() % 100;
    sort(array1, array1 + size, greater<int>());
    for (int i = 0; i < size; i++)
        cout<<array1[i]<<" ";
    return 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
#include <iostream>
#include <algorithm>
#include <ctime>
using namespace std;
 
int main ()
{
    setlocale (LC_CTYPE, "Russian");
    srand(time(NULL));
 
    const int size = 25;
    int array1[size];
 
    for (int i = 0; i < size; i++)
    {
        array1[i] = 1 + rand() % 100;
        sort(array1, array1 + i + 1, greater<int>());
    }
    
    for (int i = 0; i < size; i++)
        cout<<array1[i]<<" ";
    return 0;
}
diagon
Higher
 Аватар для diagon
1920 / 1186 / 49
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
19.05.2012, 18:32     Заполнить массив убывающими элементами #5
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
int main()
{
       const int n = 15;
       std::vector< int > arr(n);
       std::iota( arr.rbegin(), arr.rend(), 1 );
       std::copy( arr.begin(), arr.end(), std::ostream_iterator< int > (std::cout, " ") );
}
http://liveworkspace.org/code/61cc17...03e2b39162b608
Yandex
Объявления
19.05.2012, 18:32     Заполнить массив убывающими элементами
Ответ Создать тему
Опции темы

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