1.特殊三位数
#include<iostream>
using namespace std;
int fun(int x)
{
int i,m=1;
for(i=x;i>0;i--)
m*=i;
return m;
}
int main()
{
int i,a,b,c;
cout<<"三位数中所有满足条件n=a!+b!+c!的三位数为:\n";
for(i=100;i<1000;i++)
{
a=(i/10)/10;
b=(i/10)%10;
c=i%10;
if(i==fun(a)+fun(b)+fun(c))
cout<<i<<'\t';
}
cout<<endl;
}
2.素数和回文
#include <iostream>
using namespace std;
int isPrimer(int n)//判断数是否为素数
{
int i=2;
for(i=2;i<n;i++)
{if(n%i==0) break;}
if(n==i) return 1;
else return 0;
}
int isPalindrome(int n)//判断数是否为回文
{
int a=0;
while(n)
{a=a*10+n%10;
n/=10;}
return a;
}
int main()
{
int x,y,z,i,j=0,k=0,l=0,m=0;
int a[80],b[80],c[80],d[80];
for(i=2;i<=300;i++)
{
x=isPrimer(i);
y=isPalindrome(i);
z=isPrimer(y);
if(x==1) {a[j]=i;j++;}//将素数放入a数组
if(y==i) {b[k]=i;k++;}//将回文数放入b数组
if(x==1&&y==i) {c[l]=i;l++;}//将回文素数放入c数组
if(x==1&&z==1) {d[m]=i;m++;}//将可逆素数放入d数组
}
cout<<"300以内的所有素数:"<<'\n';
for(i=0;i<j;i++)
cout<<a[i]<<" ";
cout<<endl;
cout<<"300以内的所有回文数:"<<'\n';
for(i=0;i<k;i++)
cout<<b[i]<<" ";
cout<<endl;
cout<<"300以内的所有回文素数:"<<'\n';
for(i=0;i<l;i++)
cout<<c[i]<<" ";
cout<<endl;
cout<<"300以内的所有可逆素数:"<<'\n';
for(i=0;i<m;i++)
cout<<d[i]<<" ";
cout<<endl;
}