标题:_函数---判断可逆素数,看看哪里错了,望指出
只看楼主
xue12356
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2016-12-10
结帖率:0
已结贴  问题点数:20 回复次数:3 
_函数---判断可逆素数,看看哪里错了,望指出
【问题描述】若将某一素数的各位数字的顺序颠倒后得到的数仍是素数,则此素数称为可逆素数。编写一个判断某数是否可逆素数的函数,在主函数中输入一个整数,再调用此函数进行判断
【输入形式】用户在第一行输入一个整数。
【输出形式】程序在下一行输出yes或是no,yes表示此数是可逆素数,no表示不是。用户输入的数必须为正整数。注意:yes或是no全是小写输出。
【样例输入】23
【样例输出】no
【样例说明】用户输入23,23各位数字颠倒之后得到32,23是素数,但32不是素数,所以23不是可逆素数。
#include<stdio.h>
 int main()
 {int ssu1(int x),ssul(int x),x,p,q,y;
  
scanf("%d",&x);
  p=ssu2(x);
if(p==0)
printf("no");
else
q=ssu1(x);
y=ssu2(q);
  if(y==1)
    printf("yes");
   else printf("no");
}
int ssu1(int x)
{int sum,n,x;

   while(n){
        sum=n%10+sum*10;
        n/=10;
    }

return sum;
 
}
int ssu2(int x)
{int m,p,x;
for(m=2;m<=x;m++)
if(x%m==0)break;
if(m==x)
return 1;
else return 0;
      
    }
搜索更多相关主题的帖子: include 正整数 用户 
2016-12-10 17:56
marlow
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:125
专家分:419
注 册:2016-7-18
得分:10 
没一条注释,看得累:编一个is_prime(n)函,如果n=23和=32返回值都为真,即为逆素数,关于素数的讨论这几天很多,你可以找到这个函数

一切都在学习、尝试、摸索中
2016-12-10 18:48
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:10 
/*10-100之间的互逆素数(如13是素数 31也是素数)*/
#include<stdio.h>
#include<math.h>

int _isprimer(int n)
{
    int i;
    for (i=2; i<=sqrt(n); i++)
    {
        if (n % i == 0)
            return 0;
    }
    return 1;
}

int _inverse(int n)  
{
    int m=0, a;
    while(n > 0)
    {
        a = n % 10;
        m = m * 10 + a;
        n = n / 10;
    }
    return m;
}

main()
{
    int i;
    for (i=10; i<=100; i++)
    {
        if (_isprimer(i) && _isprimer(_inverse(i)))
            printf("%d\n", i);
    }
}
2016-12-10 19:59
marlow
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:125
专家分:419
注 册:2016-7-18
得分:0 
/* inverseprime.c:逆素数 */
#include<stdio.h>
 int main()
 {
     int ssu1(int x),ssul(int x),x,p,q,y;
  
    while(scanf("%d",&x) == 1){
        p=ssu2(x);
        if(p==0)
            printf("no");
        else
            q=ssu1(x);
        y=ssu2(q);
        if(y==1)
            printf("yes");
        else
            printf("no");
        
    }
    return 0;
}

int ssu1(int n)
{
    int sum = 0;

    while(n){
        sum=n%10+sum*10;
        n/=10;
    }
    return sum;
}

int ssu2(int x)
{
    int m;
   
    for(m=2;m<=x;m++)
        if(x%m==0)
            break;
    if(m==x)
        return 1;
    else
        return 0;
}
//这样就好了

一切都在学习、尝试、摸索中
2016-12-10 19:59



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-472234-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.073505 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved