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

Отсортировать по возрастанию числа и вывести те, которые меньше a - C++

Восстановить пароль Регистрация
 
dota
3 / 3 / 0
Регистрация: 20.09.2010
Сообщений: 100
10.02.2012, 21:21     Отсортировать по возрастанию числа и вывести те, которые меньше a #1
Задание такое : дано некоторое число n , затем вводится n чисел , после этого вводится два числа a и b.
Нужно : среди этих n чисел отсортировать по возрастанию и вывести те , которые меньше a ; отсортировать по убыванию и вывести те , которые больше b.
Вот мой код. Он работает(все делал через массивы) . Ошибок и предупреждений нет . С сортировкой тоже проблем нет . Проблема с нахождением чисел в массиве(почему-то программа либо игнорирует число , которое в принципе нам подходит , либо выводит ересь типа -6.27744e+066) . Даже не знаю , в чем ошибка . Вроде бы с точки зрения алгоритма все не так уж и плохо ) В любом случае , надеюсь на авторитетное мнение профессионалов )
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
#include<iostream.h>
int main()
{
    const int n = 5;
    double arr[n];
    
    cout<<"Enter the array :"<<endl;        
    for(int i=0;i<n;i++) cin>>arr[i];       
    cout<<"You have entered array :"<<endl; 
    for(i=0;i<n;i++) cout<<arr[i]<<endl;
 
    double a,b;
    cout<<"Enter a and b :"<<endl;
    cin>>a>>b;
 
    int n1=0;
    int n2=0;   
    
        for(i=0;i<n;i++) {
            if(arr[i]<=a) n1++;
    }
 
    for(i=0;i<n;i++) {
            if(arr[i]>=b) n2++;
    }
    
    double * m1 = new double[n1];
    double * m2 = new double[n2];
 
    int s1=0;
    int s2=0;
 
    while (s1<n1 ) {
    for( i=0;i<n;i++) {
        if(arr[i]<=a) m1[s1]=arr[i];s1++;}
    }
 
    while (s2<n2 ) {
    for( i=0;i<n;i++) {
        if(arr[i]>=b) m2[s2]=arr[i];s2++;}
    }
    
cout<<"*****The first sequence*****"<<endl;
 
        for(i=0;i<n1-1;i++){
            int i_min=i;
            for(int j=i+1;j<n1;j++)
                if(m1[j]<m1[i_min]) i_min=j;
                double tmp=m1[i];
                m1[i]=m1[i_min];
                m1[i_min]=tmp;
        }
 
        for(i=0;i<n1;i++)  cout<<m1[i]<<endl;
    
cout<<"*****The second sequence*****"<<endl;
 
        for(i=0;i<n-1;i++){
            int i_max=i;
            for(int j=i+1;j<n2;j++)
                if(m2[j]>m2[i_max]) i_max=j;
                double tmp=m2[i];
                m2[i]=m2[i_max];
                m2[i_max]=tmp;
        } 
 
for( i=0;i<n2;i++) cout<<m2[i]<<endl;
 
return 0;
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.02.2012, 21:21     Отсортировать по возрастанию числа и вывести те, которые меньше a
Посмотрите здесь:

Найти в каждом столбце матрицы G элементы, которые больше числа А и меньше числа С C++
C++ Отсортировать массив по возрастанию и вывести на экран
Отсортировать и вывести трапеции по возрастанию их периметров C++
в прямоугольной целочисленная матрицы отсортировать элементы которые размещены на главной диагонали по возрастанию C++
Отсортировать и вывести цилиндры по возрастанию объемов C++
Вывести числа, которые почти равны друг другу (их разность меньше 0,01) C++
Вывести квадраты натуральных чисел, которые меньше указаного числа C++
C++ Отсортировать чётные ЧИСЛА по возрастанию

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OstapBender
 Аватар для OstapBender
581 / 519 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
10.02.2012, 22:56     Отсортировать по возрастанию числа и вывести те, которые меньше a #2
чо опять без STL ? (
remarkes
300 / 223 / 13
Регистрация: 01.07.2011
Сообщений: 809
Записей в блоге: 1
10.02.2012, 23:41     Отсортировать по возрастанию числа и вывести те, которые меньше a #3
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include <iostream>
 
using namespace std;
int main()
{
    const int n = 5;
    int tmp;
    int arr[5]={11,12,13,14,15};
    int i, j;
    int i_min, i_max;
    int a=12;
    int b=13;
    int n1=0;
    int n2=0;
    int s1=0;
    int s2=0;
    
    //~ cout<<"Enter the array :"<<endl;        
    //~ for(i=0;i<n;i++) cin>>arr[i];          
    //~ cout<<"You have entered array :"<<endl; 
    //~ for(i=0;i<n;i++) cout<<arr[i]<<endl;
 //~ 
    //~ cout<<"Enter a and b :"<<endl;
    //~ cin>>a>>b;
 
    for(i=0;i<n;i++) {
        if(arr[i]<=a)
            n1++;
    }
 
    for(i=0;i<n;i++) {
        if(arr[i]>=b)
            n2++;
    }
 
    int * m1 = new int[n1];
    int * m2 = new int[n2];
 
    while (s1<n1) {
        for(i=0;i<n;i++) {
            if (arr[i]<=a) {
                m1[s1]=arr[i];
                s1++;
            }
        }
    }
 
    while ( s2 < n2 ) {
        for (i=0; i<n; i++) {
            if ( arr[i] >= b ) {
                m2[s2]=arr[i];
                s2++;
            }
        }
    }
 
cout<<"*****The first sequence*****"<<endl;
 
    for (i=0; i < n1-1; i++) {
        i_min=i;
        for(j=i+1;j<n1;j++)
            if(m1[j]<m1[i_min]) i_min=j;
            tmp=m1[i];
            m1[i]=m1[i_min];
            m1[i_min]=tmp;
    }
 
    for(i=0;i<n1;i++)
        cout<<m1[i]<<endl;
    
cout<<"*****The second sequence*****"<<endl;
 
    for(i=0;i<n2-1;i++){
        i_max=i;
        for(j=i+1;j<n2;j++)
            if(m2[j]<m2[i_max]) i_max=j;
            tmp=m2[i];
            m2[i]=m2[i_max];
            m2[i_max]=tmp;
    }
 
    cout<<"\n";
    for(i=0;i<n2;i++)
        cout<<m2[i]<<endl;
     
    return 0;
}
Добавлено через 36 минут
Цитата Сообщение от dota Посмотреть сообщение
надеюсь на авторитетное мнение профессионалов )
я не могу назвать себя профессионалом, но некоторые полезные советы дам:
1. объявляй переменные вначале функции, а не в середине кода. обрати внимание на то, что ты объявляешь одни и те же переменные несколько раз. это очень важно для понимания, и не важно, какой это язык программирования.
2. не имей привычку писать for (int i=0..., особенно в каждом цикле. просто объяви вначале функции int i; и используй просто for (i=0;... некоторые компиляторы ругаются от такого подхода.
3. не пиши несколько операторов подряд. это очень затрудняет чтение и логику!
я полчаса бился в поисках одной из ошибок, просто потому, что операторы были написаны в одну строку. крылась здесь:
Цитата Сообщение от dota Посмотреть сообщение
if(arr[i]<=a) m1[s1]=arr[i];s1++;}
тоже самое
Цитата Сообщение от dota Посмотреть сообщение
if(arr[i]>=b) m2[s2]=arr[i];s2++;}
более того, твоя закрывающая скобка - это скобка цикла while, а кажется, что условия.
4. прочитай в интернете про стиль написания исходного кода. попроси вам рассказать об этом преподавателя.
5. научись комментировать свой код, в смысле - использовать комментарии в коде.
6. не стесняйся ставить пробелы в коде, чтобы логически отделить операнды и операторы. В сложных выражениях это просто необходимая вещь. Например, так.
C++
1
for (i=0; i < n1-1; i++) {
По поводу кода:
я немного упростил код, надеюсь, ты разберешься. double перевел в инт, отключил ввод переменных.
слишком много лишних переменных. s1, s2; i_min, i_max;
много повторяющихся одинаковых блоков. вместо них обычно пишут функции.

Добавлено через 2 минуты
Цитата Сообщение от OstapBender Посмотреть сообщение
чо опять без STL ? (
Степанов негодуэ
dota
3 / 3 / 0
Регистрация: 20.09.2010
Сообщений: 100
11.02.2012, 16:08  [ТС]     Отсортировать по возрастанию числа и вывести те, которые меньше a #4
Спасибо за советы и за код .
Yandex
Объявления
11.02.2012, 16:08     Отсортировать по возрастанию числа и вывести те, которые меньше a
Ответ Создать тему
Опции темы

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