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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ 866=> Windows-кодировка... http://www.cyberforum.ru/cpp-beginners/thread444153.html
Ищу функцию для перевода из DOS кодировки 866 в Windows-кодировку на Си... Может есть у кого??
C++ Число дней недели между датами Добрый вечер. Есть две даты:начальная и конечная. И есть номер дня недели:1-воскрксенье, 2-понедельник...,7-суббота. Помогите написать функцию, которая бы считала: число конкретного номера дня недели между двумя датами. Добавлено через 40 минут Очень нужно. Пишу на с++. Добавлено через 15 часов 57 минут Может кто-нибудь писал такую функцию? http://www.cyberforum.ru/cpp-beginners/thread444151.html
C++ целочисленной арифметике
Определить, сколько цифр в каждом числе n из заданной последовательности чисел. Если количество цифр чётное, то получить из него число такое, чтобы цифры в нём следовали в обратном порядке.
Генерация массива всех перестановок из n элементов. C++
Нашел по этой теме здесь на форумах такой код: #include <iostream.h> int X; int N; void Swap(int a,int b) { int t=X; X=X; X=t;
C++ перевессти байты в слово http://www.cyberforum.ru/cpp-beginners/thread444056.html
привет)))есть массив байтов(шестнадцатеричный) 53 48 4f 52 54 и т.д., есть признак того, что этому массиву соответсвует либо int, либо float, либо вообще целое слово(char ), либо insigned int. нужно их перевести в слово,int ,float и т.е. какое слово соответсвует этому набору байтов, кодировка ANSI, какая функция все это переводит...скажите плиз))))на языке С/С++. Добавлено через 1 минуту я...
C++ Найти сумму квадратов чисел от A до B Нужно ввести с клавиатуры A и B, чтобы программы выдавала на экран сумму квадратов чисел от A доB. подробнее

Показать сообщение отдельно
dota
3 / 3 / 0
Регистрация: 20.09.2010
Сообщений: 100
10.02.2012, 21:21     Отсортировать по возрастанию числа и вывести те, которые меньше a
Задание такое : дано некоторое число 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 14:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru