Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 25, средняя оценка - 4.88
vorant
0 / 0 / 1
Регистрация: 13.11.2012
Сообщений: 20
#1

Четность/нечетность - C++

14.02.2013, 22:52. Просмотров 5581. Ответов 16
Метки нет (Все метки)

Как определить четность/нечетность числа (использовать остаток от деления нацело (%) и другие бинарные функции нельзя)?
http://www.cyberforum.ru/cpp-beginners/thread246982.html
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.02.2013, 22:52
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Четность/нечетность (C++):

Четность, нечетность наборов чисел
Нужно вывести на экран набор чисел по четным и нечетным ПОЗИЦИЯМ (не сами...

Четность/нечетность строк в двумерном массиве
Подскажите, пожалуйста, как получить условие в двумерном массиве на...

Проверить число на нечетность
// zadanie 7_suma kubov ne chentich chisel.cpp: определяет точку входа для...

Проверить нечетность числа (Турбо Си)
как указать нечётность в Турбо Си

Проверка элемента одномерного массива на нечетность, вычисление числа нечетных элементов
Помогите, пожалуйста, с задачей: Создать объектный тип данных-вектор,...

16
ValeryS
Модератор
7124 / 5392 / 669
Регистрация: 14.02.2011
Сообщений: 18,210
14.02.2013, 22:57 #2
C++
1
2
3
4
if(m&1)
 // нечетное
else
// четное
Добавлено через 3 минуты
извращенный способ (для положительных)
C++
1
2
3
4
5
6
while(m>0)
 m-=2;
if(m)
 // нечетное
else
// четное
2
vorant
0 / 0 / 1
Регистрация: 13.11.2012
Сообщений: 20
14.02.2013, 23:15  [ТС] #3
Цитата Сообщение от ValeryS Посмотреть сообщение
C++
1
2
3
4
if(m&1)
 // нечетное
else
// четное
не работает с double (functions.cpp:23:14: error: invalid operands of types 'double' and 'int' to binary 'operator&')

Цитата Сообщение от ValeryS Посмотреть сообщение
Добавлено через 3 минуты
извращенный способ (для положительных)
C++
1
2
3
4
5
6
while(m>0)
 m-=2;
if(m)
 // нечетное
else
// четное
действительно извращенный)) нужен более компактный и универсальный; а то прописывать if на положительность/отрицательность и два таких цикла... программа долго работать же будет, особенно с большими числами...

Добавлено через 3 минуты
C++
1
2
3
4
5
6
7
8
9
10
void third(int *pA, int size){
    int x=0; 
    for(int i=0;i<size;i++){
        if((sqrt(pA[i]))&1){
        }else{
            x++;
        }
    }
    printf("chisel, kotorie kvadrati chetnih chisel --> %d\n", x);
}
код программы (с ошибкой)
0
ValeryS
Модератор
7124 / 5392 / 669
Регистрация: 14.02.2011
Сообщений: 18,210
14.02.2013, 23:28 #4
Цитата Сообщение от vorant Посмотреть сообщение
не работает с double
а с double и % не сработает
и цикл не выйдет
число 0.2 это четное или нечетное?


Цитата Сообщение от vorant Посмотреть сообщение
if((sqrt(pA[i]))&1){
и что ты пытался сделать?
что за массив int?
0
Kgfq
74 / 37 / 3
Регистрация: 23.09.2012
Сообщений: 408
15.02.2013, 01:31 #5
C++
1
2
int a = 7, b = a/2;
if(a - b*2 == 1) // нечетн
0
ValeryS
Модератор
7124 / 5392 / 669
Регистрация: 14.02.2011
Сообщений: 18,210
15.02.2013, 01:37 #6
Kgfq,
а тебе не кажется что ты остаток от деления привел?
общая формула
a%b= a-(a/b)*b
Цитата Сообщение от Kgfq Посмотреть сообщение
if(a - b*2 == 1)
если равно 1 то четное?
0
Toshkarik
1148 / 865 / 90
Регистрация: 03.08.2011
Сообщений: 2,404
Завершенные тесты: 1
15.02.2013, 01:59 #7
Цитата Сообщение от vorant Посмотреть сообщение
другие бинарные функции нельзя
Эм, и как же тогда это сделать? +,-,*,/ все это бинарные операторы, включая битовые операторы, кроме дополнения. Да то же сравнение ( == ) это бинарный оператор. Что то в этом задании не то.

Добавлено через 2 минуты
А так, если и битовые нельзя:
C++
1
2
if (( a / 2 ) * 2 != a )
   //нечетное
0
vorant
0 / 0 / 1
Регистрация: 13.11.2012
Сообщений: 20
15.02.2013, 07:37  [ТС] #8
Цитата Сообщение от Toshkarik Посмотреть сообщение
Эм, и как же тогда это сделать? +,-,*,/ все это бинарные операторы,
значит я неправильно выразился, мне нужно узнать четность/нечетность double переменной; есть ограничения по использованию операторов с переменными double и в этом-то и проблема...
Цитата Сообщение от Toshkarik Посмотреть сообщение
Добавлено через 2 минуты
А так, если и битовые нельзя:
C++
1
2
if (( a / 2 ) * 2 != a )
   //нечетное
так не выйдет, ведь a по условию не integer, а double.
Цитата Сообщение от Kgfq Посмотреть сообщение
C++
1
2
int a = 7, b = a/2;
if(a - b*2 == 1) // нечетн
мне нужно работать с double!!! если для double такого способа нет, так и скажите

Добавлено через 7 минут
Цитата Сообщение от ValeryS Посмотреть сообщение
а с double и % не сработает
и цикл не выйдет
число 0.2 это четное или нечетное?
в этом и проблема! после использования sqrt, который необходимо использовать, остается double-значение и мне необходимо узнать его четность/нечетность. дробные числа по-определению нечетные все



Цитата Сообщение от ValeryS Посмотреть сообщение
и что ты пытался сделать?
что за массив int?
я передаю в функцию массив и проверяю на четность/нечетность квадратный корень каждого из элементов. то есть корень из 16 будет 4, 4 - четное, значит счетчик считает; корень из 9 будет 3 - нечетное, значит счетчик не реагирует
0
Toshkarik
1148 / 865 / 90
Регистрация: 03.08.2011
Сообщений: 2,404
Завершенные тесты: 1
15.02.2013, 07:38 #9
vorant, эм, Вы в курсе, что вещественные числа не имеют свойства "четное/нечетное" ни в C++ ни в математике? Это не имеет никакого смысла.
0
vorant
0 / 0 / 1
Регистрация: 13.11.2012
Сообщений: 20
15.02.2013, 07:42  [ТС] #10
Цитата Сообщение от Toshkarik Посмотреть сообщение
vorant, эм, Вы в курсе, что вещественные числа не имеют свойства "четное/нечетное" ни в C++ ни в математике? Это не имеет никакого смысла.
любое натуральное число - вещественное!!! если в ряде вещественных чисел есть натуральные (но с типом данных double) можно ли определить четность/нечетность этих нескольких чисел. если нам дан массив из чисел 1/2, 3/10, 5, 8, 54/63 и все это double, можно ли определить четность 8 и нечетность 5?
0
Toshkarik
1148 / 865 / 90
Регистрация: 03.08.2011
Сообщений: 2,404
Завершенные тесты: 1
15.02.2013, 07:48 #11
Нет. Так как тип double хранит приближенное значение. http://www.cyberforum.ru/blogs/18334/blog88.html
1
kuli4ok
32 / 32 / 17
Регистрация: 10.10.2012
Сообщений: 88
15.02.2013, 07:50 #12
Способ откровенно извращенский, но все же рабочий, в виде функции:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
bool check(double x)
{
    x /= 2;
    char *buff = new char[30];
    sprintf(buff, "%f", x);
    for(int i=0; buff[i]!='\0'; i++)
    {
        if(buff[i]=='.')
        {
            for(int j=i+1; buff[j]!='\0'; j++)
            {
                if(buff[j]!='0')
                {
                    delete [] buff;
                    return false;
                }
            }
            delete [] buff;
            return true;
        }
    }
}
0
ValeryS
Модератор
7124 / 5392 / 669
Регистрация: 14.02.2011
Сообщений: 18,210
15.02.2013, 09:21 #13
Цитата Сообщение от vorant Посмотреть сообщение
я передаю в функцию массив и проверяю на четность/нечетность квадратный корень каждого из элементов. то есть корень из 16 будет 4, 4 - четное, значит счетчик считает; корень из 9 будет 3 - нечетное, значит счетчик не реагирует
так бы сразу и сказал
тебе нужно узнать четные корни или нет , но до этого нужно узнать натуральный ли корень
ибо число 4.48 четное или нет
дублю приведи к инт

C++
1
2
3
4
5
6
7
8
int m=sqrt(a);
if(a-m)
 //ненатуральное число,значит нечетное
else
 if(m&1)
 // нечетное
else
 // четное
только есть один маленький нюанс sqrt может вернуть приближенное значение
например корень из 16 может выглядеть так 3.999999999999999999999
1
OhMyGodSoLong
~ Эврика! ~
1245 / 994 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
15.02.2013, 09:41 #14
Цитата Сообщение от vorant Посмотреть сообщение
любое натуральное число - вещественное!!! если в ряде вещественных чисел есть натуральные (но с типом данных double) можно ли определить четность/нечетность этих нескольких чисел. если нам дан массив из чисел 1/2, 3/10, 5, 8, 54/63 и все это double, можно ли определить четность 8 и нечетность 5?
Ну, эта...
1. Проверяем равенство числа нулю. Если ноль, то чётное.
2. Проверяем, представимо ли число с помощью какого-нибудь инта. Если оно слишком большое, то технически его можно считать чётным, но вообще сказать наверняка нельзя, потому что младшие разряды потеряны из-за ограниченности дабла.
3. Если представимо, то приводим к инту, потом обратно в дабл и вычитаем из дабла. Если разность не равна нулю, то исходное число не целое и, соответственно, ни чётное, ни нечётное.
4. Иначе проверяем на чётность тот инт.
5. Что делать с нанами и бесконечностями, думайте сами.
0
ValeryS
Модератор
7124 / 5392 / 669
Регистрация: 14.02.2011
Сообщений: 18,210
15.02.2013, 09:54 #15
Цитата Сообщение от ValeryS Посмотреть сообщение
int m=sqrt(a);
if(a-m)
//ненатуральное число,значит нечетное
else
if(m&1)
// нечетное
else
// четное
пардон наврал несколько
вот так правильней
C++
1
2
3
4
5
6
7
8
9
double b=sqrt(a);
int m=b;
if(b-m)
 //ненатуральное число,значит нечетное
else
 if(m&1)
 // нечетное
else
 // четное
Добавлено через 5 минут
чтобы исключить приближенные числа можно сделать так
C++
1
if(fabs(b-m)>0.0000001)
0
daslex
1291 / 535 / 177
Регистрация: 02.08.2011
Сообщений: 2,756
15.02.2013, 10:50 #16
А если так

C++
1
2
3
    
        x-floor(x)>0? cout<<"Нечетное\n":       
             (int)x&1?cout<<"Нечетное\n":cout<<"Четное\n"; //Тернарная опреация в тернарной операции
Добавлено через 7 минут

Не по теме:

не увидел, что написано уже

0
Kgfq
74 / 37 / 3
Регистрация: 23.09.2012
Сообщений: 408
15.02.2013, 13:16 #17
vorant, Чётность в теории чисел — характеристика целого числа, определяющая его способность делиться нацело на два.
0
15.02.2013, 13:16
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.02.2013, 13:16
Привет! Вот еще темы с решениями:

Четность чисел
Господа, можете помочь со следующей задачей по С++: Вводятся числа a и b....

Определить четность чисел
Определить четность чисел 541, 1024.

Проверить число на четность
Определить, я вляется ли значение цилочисленный пременный x чётными, если...

проверка на четность и массивы
Помогите пожалуйста!! 1. Определить, является ли заданное целое число А...


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru