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

Если число является простым, то функция возвращает true, если не является false - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
NSTR
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 76
06.02.2014, 14:22     Если число является простым, то функция возвращает true, если не является false #1
Напишите функцию, получающую целое число N(>0). Если оно является простым, то функция возвращает true, если не является false.
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
#include <iostream>
#include <cmath>
 
using namespace std;
 
int func (int N);
 
int main()
{
    int n;
    cout<<"Enter number:";
    cin>>n;
    func (n);
    return 0;
}
 
int func (int N)
{
    if (N==0){
        cout<<"false"<<endl;
        
        }
    if (N==1){
        cout<<"false"<<endl;
        
        }
    for (int i=1;i<N;i++){
        if ((N%i==0)&&(N/1==N)){
            cout<<"false"<<endl;
            }
        else if (i==N-1){
            cout<<"true"<<endl;
            }
            
    }
    system("pause");
}
У меня получается какой-то бред) Можете подсказать?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.02.2014, 14:22     Если число является простым, то функция возвращает true, если не является false
Посмотрите здесь:

C++ While4°. Дано целое число N (> 0). Если оно является степенью числа 3, то вывести true, если не является — вывести false.
C++ Составить линейную программу, печатающую значение true, если указанное высказывание является истинным, и false - в противном случае.
Составить линейную программу, печатающую значение true, если указанное высказывание является истинным, и false - в противном случае. C++
Описать функцию IsPrime(N) логического типа, возвращающую True, если целый параметр N (> 1) является простым числом C++
Дано целое число N(>0). Если оно является степенью числа 3, то вывести TRUE, если не является-вывести FALSE. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Chernobyl
211 / 211 / 67
Регистрация: 30.09.2012
Сообщений: 526
06.02.2014, 14:33     Если число является простым, то функция возвращает true, если не является false #2
C++
1
2
3
4
5
6
7
8
9
10
11
bool simple(int n, bool answer){
    vector<bool> buf; 
    for(int i=2;i<=n-1;i++){
        if( n%i != 0 ) buf.push_back(true);
        else buf.push_back(false);
    }
    for(int i=0;i<buf.size();i++){
        if(buf[i] == false) answer = false;
    }
    return answer;
}
sergei60
47 / 28 / 4
Регистрация: 10.06.2012
Сообщений: 334
06.02.2014, 14:35     Если число является простым, то функция возвращает true, если не является false #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
    #include <iostream>
    using namespace std;
     
    int main() {
     int n
    int prime;
    prime=true;
    cout<<"ввести число: ";
    cin>>n;
    for ( int i=2; i<n; i++)
    {
    if (n%i == 0){
     
    prime = false;
    cout<<i<<","<<endl;
    }
     
    }
     
    if (prime)
    cout<<"простое."<<endl;
    else
    cout<<"не простое!" ;
    return 0;
    }
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
06.02.2014, 14:45     Если число является простым, то функция возвращает true, если не является false #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include <iostream>
#include <cmath>
 
using namespace std;
 
void func (int N);
 
int main()
{
    int n;
    cout<<"Enter number:";
    cin>>n;
    func (n);
    return 0;
}
 
void func (int N)
{
    bool b=false;
  if (N>1)
    for (int i=2;i<N;i++) if (N%i==0) b=true;
b ? cout<<"true"<<endl : cout<<"false"<<endl;            
    system("pause");
}
sergei60
47 / 28 / 4
Регистрация: 10.06.2012
Сообщений: 334
06.02.2014, 14:52     Если число является простым, то функция возвращает true, если не является false #5
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include <iostream>
#include <cmath>
 
using namespace std;
 
int func (int N);
 
int main()
{
    int n;
    cout<<"введите число:";
    cin>>n;
    func (n);
    return 0;
}
 
int func (int N)
{
    if (N==0){
        cout<<"непростое"<<endl;
        
        }
    if (N==1){
        cout<<"непростое"<<endl;
        
        }
    for (int i=2;i<N;i++){
        if (N%i==0){
            cout<<"непростое"<<endl;
            return false;
            }
        else if (i==N-1){
            cout<<"простое"<<endl;
            }
        }
         return 0;   
    }
Это твой код исправленный.
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
06.02.2014, 14:58     Если число является простым, то функция возвращает true, если не является false #6
Chernobyl, красивый год, но уместно ли vector сюда? да кстати он выведет скорее всего всегда false!:
для 4 цикл закончится при i=3,
C++
1
2
for(int i=0;i<buf.size();i++){
        if(buf[i] == false) answer = false;
при этом buf[3]=false следовательно и в итоге answer=false;

Добавлено через 4 минуты
Мой код наоборот дает (проверка на не простое)...
Chernobyl
211 / 211 / 67
Регистрация: 30.09.2012
Сообщений: 526
06.02.2014, 15:17     Если число является простым, то функция возвращает true, если не является false #7
mustimur, Нет, я ничего такого не заметил. Код работает хорошо. Я его немного изменил и попытался вывести все простые число от 2 до... Все выходит отлично.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using namespace std;
bool simple(int n){
    bool answer = true;
    vector<bool> buf; 
    for(int i=2;i<=n-1;i++){
        if( n%i != 0 ) buf.push_back(true);
        else buf.push_back(false);
    }
    for(int i=0;i<buf.size();i++){
        if(buf[i] == false) answer = false;
    }
    return answer;
}
 
int main()
{
    for (int i=2;i<101;i++){
    if(simple(i)) cout<<i<<endl;
    }
}
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
06.02.2014, 15:30     Если число является простым, то функция возвращает true, если не является false #8
Chernobyl, простите в 6 строчке отрицание не увидел, вы правы)
NSTR
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 76
06.02.2014, 15:33  [ТС]     Если число является простым, то функция возвращает true, если не является false #9
mustimur, хм, странно. Нужно поменять местами true и false, чтобы было верно.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int func (int N)
{
    bool b;
    if (N>1)
    for (int i=2;i<N;i++) 
        if (N%i==0) 
            b=true;
    if (b==true)
        cout<<"false"<<endl;
    else
        cout<<"true"<<endl;
    
          
    system("pause");
}
mustimur
268 / 222 / 57
Регистрация: 22.11.2013
Сообщений: 832
Записей в блоге: 1
06.02.2014, 15:40     Если число является простым, то функция возвращает true, если не является false #10
Цитата Сообщение от NSTR Посмотреть сообщение
mustimur, хм, странно. Нужно поменять местами true и false, чтобы было верно.
Да понял я это (6 пост) проверка на непростое сделана (невнимательно задание прочел невнимательность - мой бич) проще так:
C++
1
b! ? cout<<"true"<<endl : cout<<"false"<<endl;
NSTR
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 76
06.02.2014, 15:44  [ТС]     Если число является простым, то функция возвращает true, если не является false #11
Цитата Сообщение от mustimur Посмотреть сообщение
Да понял я это (6 пост) проверка на непростое сделана (невнимательно задание прочел невнимательность - мой бич) проще так:
C++
1
b! ? cout<<"true"<<endl : cout<<"false"<<endl;
Ну все ок тогда. Спасибо)
Btorkoy
0 / 0 / 0
Регистрация: 05.04.2014
Сообщений: 5
06.08.2015, 14:48     Если число является простым, то функция возвращает true, если не является false #12
я только начинаю кодить, вот мое решение:
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
#include <iostream >
#include <cmath>
using namespace std;
int Nod(int x)
{
    int n = 0;
    for (int i = 2; i < x; i++)
    {
        if ( x % i == 0)
        {
        n = i;
        }
    }
    if (n == 0)
    { 
        cout << "Yes" << endl;
    }
    else
    {
        cout << "No" << endl;
    }
 
    
}
 
int main()
{
    int a;
 
    cout << "Input a:  " << endl;
    cin >> a;
    Nod (a);
 
    
    system ("pause");
    return 0; 
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.08.2015, 15:02     Если число является простым, то функция возвращает true, если не является false
Еще ссылки по теме:

Описать функцию, возвращающую true, если натуральное число является простым, и false в противном случае C++
C++ Программа, печатающая значение true, если указанное высказывание является истинным, и false в противном случае

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

Или воспользуйтесь поиском по форуму:
Krock21rus
73 / 73 / 19
Регистрация: 18.11.2013
Сообщений: 369
Завершенные тесты: 2
06.08.2015, 15:02     Если число является простым, то функция возвращает true, если не является false #13
у вас почти всё норм, долго и глупо, но почти правильно, следует только цикл начинать с 2 а не с 1

Добавлено через 1 минуту
C++
1
2
3
4
5
6
7
bool test(int n)
{
 int end = sqrt(n)+1;
 for(int i=2;i<end;i++)
   if(n%i==0) return false;
 return true;
}
Добавлено через 43 секунды
а вот ваше исправленное:
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
#include <iostream>
#include <cmath>
 
using namespace std;
 
int func (int N);
 
int main()
{
    int n;
    cout<<"Enter number:";
    cin>>n;
    func (n);
    return 0;
}
 
int func (int N)
{
    if (N==0){
        cout<<"false"<<endl;
        
        }
    if (N==1){
        cout<<"false"<<endl;
        
        }
   for (int i=2;i<N;i++){ /////////////////////////////////////// я хз почему не даёт выделить элементы в коде
        if ((N%i==0)&&(N/1==N)){
            cout<<"false"<<endl;
            }
        else if (i==N-1){
            cout<<"true"<<endl;
            }
            
    }
    system("pause");
}
Добавлено через 3 минуты
а да, для ускорения можно не все подряд проходить, а только те которые являются числами 6*k+1 и 6*k-1
тогда необходимо в начале проверить на положительность и предусмотреть 1 2 3

Добавлено через 1 минуту
Цитата Сообщение от mustimur Посмотреть сообщение
b! ? cout<<"true"<<endl : cout<<"false"<<endl;
это у вас даже не скомпилируется, нет такой переменной b!
Yandex
Объявления
06.08.2015, 15:02     Если число является простым, то функция возвращает true, если не является false
Ответ Создать тему
Опции темы

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