Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.89/63: Рейтинг темы: голосов - 63, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 29.09.2011
Сообщений: 8

Даны 4 вещественных числа. Определить сколько из них отрицательных.

29.09.2011, 14:00. Показов 12041. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Даны 4 вещественных числа. Определить сколько из них отрицательных. Оператор цикла не использовать.

если можно с коментариями.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2011, 14:00
Ответы с готовыми решениями:

Даны числа a, b, c. Определить, сколько из них одинаковых
Дано числа a,b,c. Определить, сколько из них одинаковых.

целое положительное К, за которым следуют К вещественных чисел. Определите, сколько из них отрицательных. Найдите наибольшее из них
Исходные данные : целое положительное К, за которым следуют К вещественных чисел. Определите, сколько из них отрицательных. Найдите...

целое положительное К, за которым следуют К вещественных чисел. Определите, сколько из них отрицательных. Найдите наибольшее из них.
Исходные данные : целое положительное К, за которым следуют К вещественных чисел. Определите, сколько из них отрицательных. Найдите...

20
29.09.2011, 14:01
 Комментарий модератора 
учитесь называть темы информативно
1
0 / 0 / 0
Регистрация: 29.09.2011
Сообщений: 8
29.09.2011, 14:05  [ТС]
magirus, извиняюсь
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
29.09.2011, 14:23
О! Это я могу.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// Шчитаем
int Count( const float * array, int size, int i )
{
     if( size <= i )
          return 0;
     return (array[i] < 0) + Count(array, size, i+1);
}
 
int main()
{
     float array[4] = { 1.f, -5.f, 3.f, -1.f };
     // Получаем количество отрицательных чисел
     // Без использования оператора цикла
     // Какие мы молодцы то!
     int nNegatives = Count( array, 4, 0 );
 
     return 0;
}
0
0 / 0 / 0
Регистрация: 29.09.2011
Сообщений: 8
29.09.2011, 14:50  [ТС]
еще варианты пожалуйста
0
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
29.09.2011, 16:42
мона так
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
template <class T>
class number {
 
    static int count;
 
public:
    number(T n) { 
        if (n<0) count++;
    }
 
    static int how_much();
 
};
 
template <class T>
int number<T>::count = 0;
 
template<class T>
int number<T>::how_much() {
    return count;
}
 
 
int main(int argc, char* argv[])
{
    number<float> a[4] = { 1.f, -5.f, 3.f, -1.f };
 
    std::cout << number<float>::how_much() <<  '\n';            
 
 
    getchar();
    return 0;
}
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
29.09.2011, 16:49
Цитата Сообщение от OstapBender Посмотреть сообщение
мона так
Зачем человеку шаблоном пугаешь. Без шаблона функционал сохранится.

А я всё жду вопрос про "как обменять два числа?". Можно будет много красивых реализаций придумать.)
0
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
29.09.2011, 17:23
Определение количества отрицательных чисел на этапе компиляции:
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>
 
template <int ... Ints>
struct negatives;
 
template <int I, int ... Ints>
struct negatives<I, Ints ...>
{
    static const size_t count = (I < 0 ? 1 : 0) + negatives<Ints ...>::count;
};
 
template <>
struct negatives<>
{
    static const size_t count = 0;
};
    
int main()
{
    std::cout << negatives<int(-1.f), int(-5.f), int(3.f), int(-3.f)>::count << std::endl;
    
    return 0;
}
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
29.09.2011, 17:31
Уверен, что со списком типов и в старом стандарте замутить аналогичное можно.
0
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
29.09.2011, 17:33
Deviaphan, что такое "список типов"?
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
29.09.2011, 17:38
У Александрэску в "Современном проектировании" есть. Я так и не нашёл, где бы мне их использовать и уже забыл.)
1
0 / 0 / 0
Регистрация: 29.09.2011
Сообщений: 8
29.09.2011, 19:23  [ТС]
а можно эту задачу как нибудь вообще по простому решить? как решил бы человек который изучает с++ меньше месяца...
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
29.09.2011, 19:37
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int main()
{
float a[4] = { -1.0, 5.3f, -2.0f, -3.f };
 
int i = 0;
int count = 0;
NOT_A_LOOP_OPERATOR:
if( a[i] < 0 )
    count++;
i++;
if( i < 4 )
    goto NOT_A_LOOP_OPERATOR;
 
return 0;
}
1
0 / 0 / 0
Регистрация: 29.09.2011
Сообщений: 8
29.09.2011, 23:14  [ТС]
Deviaphan,
а можно последний вариан прокомментировать,просто я вообще не шарю...

1) что такое float
2) что значит f после чисел
3) что такое NOT_A_LOOP_OPERATOR:
4) что такое goto

Добавлено через 20 минут
и она не работает к сожалению
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
30.09.2011, 00:56
Цитата Сообщение от crash7007 Посмотреть сообщение
человек который изучает с++ меньше месяца
Цитата Сообщение от crash7007 Посмотреть сообщение
что такое float
за месяц два абзаца прочитал?
C++
1
2
3
4
5
6
7
8
9
10
#include <iostream>
#define negative(x)    ((x < 0) ? 1 : 0)
 
int main(){
    float arr[] = {0.01, -2.2212, -0.012, 4.4};
    for (int i = 0; i < 4; ++i)
        if(negative(arr[i]))
            std::cout << arr[i] << "\n";
     return 0;
}
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,974
30.09.2011, 03:02
Цитата Сообщение от Deviaphan Посмотреть сообщение
int Count( const float * array, int size, int i )
а зачем лишнюю переменную таскать?
C
1
2
3
size_t negative_count(const int * arr, size_t size){
    return ( size ) ? ( *arr < 0 ) + negative_count(arr + 1, size - 1) : 0;
}
нерекурсивный вариант
C
1
2
3
4
5
6
size_t negative_count(const int * arr, size_t size){
    size_t cnt = 0;
    while ( size-- )
        cnt += ( *arr++ < 0 );
    return cnt;
}
0
278 / 174 / 21
Регистрация: 10.07.2011
Сообщений: 441
30.09.2011, 04:28
Цитата Сообщение от crash7007 Посмотреть сообщение
а можно эту задачу как нибудь вообще по простому решить? как решил бы человек который изучает с++ меньше месяца...
можно.

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
#include "stdafx.h"
#include <iostream>
using std::cout;
using std::endl;
 
int main(){
    float number1 = -1.43;
    float number2 = 3.87;
    float number3 = 2.31;
    float number4 = -5.12;
    int count = 0;
 
    if(number1 < 0){
        count +=1;
    }
    if(number2 < 0){
        count +=1;
    }
    if(number3 < 0){
        count +=1;
    }
    if(number4 < 0){
        count +=1;
    }
    cout << "Otricatelnyh chisel : " << count << endl;
    system("pause");
    return 0;
}
0
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
30.09.2011, 04:53
easybudda,
alkagolik,
Цитата Сообщение от crash7007 Посмотреть сообщение
Оператор цикла не использовать
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
30.09.2011, 07:21
Точно, можно на аргумент меньше.

Добавлено через 1 минуту
Цитата Сообщение от crash7007 Посмотреть сообщение
Deviaphan,
а можно последний вариан прокомментировать,просто я вообще не шарю...

1) что такое float
2) что значит f после чисел
3) что такое NOT_A_LOOP_OPERATOR:
4) что такое goto

Добавлено через 20 минут
и она не работает к сожалению
Все работает. А в задании не сказано, что результат нужно вывести на экран, вот я и не вывожу.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
01.10.2011, 08:47
Вот подсчёт при компиляции для "устаревших" компиляторов.

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
struct NullType {};
 
template < int V, class U>
struct Typelist
{
    enum { Value = V };
    typedef U Tail;
};
 
#define TYPELIST_1(T1) Typelist<T1, NullType>
#define TYPELIST_2(T1, T2) Typelist<T1, TYPELIST_1(T2) >
#define TYPELIST_3(T1, T2, T3) Typelist<T1, TYPELIST_2(T2, T3) >
#define TYPELIST_4(T1, T2, T3, T4) Typelist<T1, TYPELIST_3(T2, T3, T4) >
 
 
template< class T > struct CountNegative;
 
template<>
struct CountNegative<NullType>
{
    enum { value = 0 };
};
 
template< int V, class U >
struct CountNegative< Typelist<V, U> >
{
    enum { value = (V < 0) + CountNegative<U>::value };
};
 
// Списки значений
typedef TYPELIST_4( int(2.0f), int(-3.4f), int(5.2f), int(-1.7f) ) ValueList1;
typedef TYPELIST_4( int(-52.4f), int(3.1415f), int(9.232f), int(10.72f) ) ValueList2;
 
int _tmain(int argc, _TCHAR* argv[])
{
    cout << "Negative in list 1 = " << CountNegative<ValueList1>::value << endl;
    cout << "Negative in list 2 = " << CountNegative<ValueList2>::value << endl;
    cin.get();
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.10.2011, 08:47
Помогаю со студенческими работами здесь

Дано 200 вещественных чисел. Определить, сколько из них больше предыдущего числа
Дано 200 вещественных чисел. Определить, сколько из них больше предыдущего числа. Заранее благодарна.

Даны три вещественных числа. Выбрать те из них, которые принадлежат интервалу (1,3). (C++)
Даны три вещественных числа. Выбрать те из них, которые принадлежат интервалу (1,3). Сделать нужно на С++. Буду очень признателен!!!...

Определить сколько среди них отрицательных и сколько положительных
Даны 8 чисел. Определить сколько среди них отрицательных и сколько положительных.

Даны три вещественных числа. Возвести в квадрат те из них, значения которых неотрицательны
int x,s; if (s&gt;=0) {x=s*s;}; Почему ответ (x) всегда равен 0?

Даны три вещественных числа, вывести на экран те из них, которые не принадлежат заданному диапазону
Даны три вещественных числа, вывести на экран те из них, которые не принадлежат диапазону (-3,8; 1,8). #include &quot;stdafx.h&quot; ...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru