Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.90/40: Рейтинг темы: голосов - 40, средняя оценка - 4.90
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 88
1

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

06.02.2014, 14:22. Просмотров 7355. Ответов 12
Метки нет (Все метки)

Напишите функцию, получающую целое число 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");
}
У меня получается какой-то бред) Можете подсказать?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
06.02.2014, 14:22
Ответы с готовыми решениями:

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

While4°. Дано целое число N (> 0). Если оно является степенью числа 3, то вывести true, если не является — вывести false.
While. Дано целое число N (&gt; 0). Если оно является степенью числа 3, то вывести true, если не...

Дано целое число N(>0). Если оно является степенью числа 3, то вывести TRUE, если не является-вывести FALSE.
Дано целое число N(&gt;0). Если оно является степенью числа 3, то вывести TRUE, если не...

Вернуть true, если параметр является алфавитно-цифровым и false в ином случае
Нужно написать функцию, которая возвращает истину, если переданный параметр является алфавитно -...

12
224 / 224 / 69
Регистрация: 30.09.2012
Сообщений: 545
06.02.2014, 14:33 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;
}
0
50 / 31 / 11
Регистрация: 10.06.2012
Сообщений: 395
06.02.2014, 14:35 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;
    }
1
319 / 225 / 73
Регистрация: 22.11.2013
Сообщений: 856
Записей в блоге: 1
06.02.2014, 14:45 4
Лучший ответ Сообщение было отмечено NSTR как решение

Решение

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");
}
1
50 / 31 / 11
Регистрация: 10.06.2012
Сообщений: 395
06.02.2014, 14:52 5
Лучший ответ Сообщение было отмечено NSTR как решение

Решение

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;   
    }
Это твой код исправленный.
1
319 / 225 / 73
Регистрация: 22.11.2013
Сообщений: 856
Записей в блоге: 1
06.02.2014, 14:58 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 минуты
Мой код наоборот дает (проверка на не простое)...
1
224 / 224 / 69
Регистрация: 30.09.2012
Сообщений: 545
06.02.2014, 15:17 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;
    }
}
1
319 / 225 / 73
Регистрация: 22.11.2013
Сообщений: 856
Записей в блоге: 1
06.02.2014, 15:30 8
Chernobyl, простите в 6 строчке отрицание не увидел, вы правы)
0
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 88
06.02.2014, 15:33  [ТС] 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");
}
0
319 / 225 / 73
Регистрация: 22.11.2013
Сообщений: 856
Записей в блоге: 1
06.02.2014, 15:40 10
Цитата Сообщение от NSTR Посмотреть сообщение
mustimur, хм, странно. Нужно поменять местами true и false, чтобы было верно.
Да понял я это (6 пост) проверка на непростое сделана (невнимательно задание прочел невнимательность - мой бич) проще так:
C++
1
b! ? cout<<"true"<<endl : cout<<"false"<<endl;
1
0 / 0 / 0
Регистрация: 29.11.2013
Сообщений: 88
06.02.2014, 15:44  [ТС] 11
Цитата Сообщение от mustimur Посмотреть сообщение
Да понял я это (6 пост) проверка на непростое сделана (невнимательно задание прочел невнимательность - мой бич) проще так:
C++
1
b! ? cout<<"true"<<endl : cout<<"false"<<endl;
Ну все ок тогда. Спасибо)
0
0 / 0 / 0
Регистрация: 05.04.2014
Сообщений: 5
06.08.2015, 14:48 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; 
}
0
84 / 80 / 31
Регистрация: 18.11.2013
Сообщений: 390
06.08.2015, 15:02 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!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.08.2015, 15:02

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Программа, печатающая значение true, если указанное высказывание является истинным, и false в противном случае
Составить программу,печатующую значение true,если указанное высказывание является истинным,и false...

Описать функцию IsPrime(N) логического типа, возвращающую True, если целый параметр N (> 1) является простым числом
Описать функцию IsPrime(N) логического типа, возвращающую True, если целый параметр N (&gt; 1)...

Составить линейную программу, печатающую значение true, если указанное высказывание является истинным, и false - в противном случае.
Помогите,пожалуйста,решить.... Составить линейную программу, печатающую значение true, если...

Составить линейную программу, печатающую значение true, если указанное высказывание является истинным, и false - в противном случае.
Составить линейную программу, печатающую значение true, если указанное высказывание является...


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

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

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