用C++编写程序求10~2000之间所有的回文数,判断一个数是否为回文数。要用函数fun(int n)来实现。

如题所述

long re(int a)
{
long int t;
for(t=0;a>0;a/=10)//将整数反序
t=t*10+a%10;
return t;
}
int nonre(lint n)//判断给定的整数是否为回文数
{
if(n>10 && n<2000)
{
if(re(n)==n)
return 1;//是返回1
else
return 0;//不是返回0
}
return 0;//不是返回0
}
void main()
{
int n,m;
int count=0;
printf("please input a number optionaly:");
scanf("%ld",&n);
printf("The genetation process of palindrome:\n");
while(!nonre((m=re(n))+n))//判断整数与其反序相加后是否为回文数
{
printf("[%d]:%ld+%ld=%ld\n",++count,n,m,m+n);
n+=m;//累加
}
printf("[%d]:%d+%ld=%ld\n",++count,n,m+n);
printf("Here we reached the aim at last.\n");//输出最好得到的回文数
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-04-05
#include<iostream>
using namespace std;
int main()
{
bool fun(int );
cout<<"10~2000之间所有的回文数:"<<endl;
for(int i =11;i<2000;i++)
{
if(fun(i))
cout<<i<<" ";

}
cout<<endl;
int num;
cout<<"请输入一个10~2000之间的数"<<endl;
cin>>num;
if(fun(num))
cout<<num<<"是回文数"<<endl;
else
cout<<num<<"不是回文数"<<endl;
return 0;
}
bool fun(int n)
{
int a[4]={0};
a[0] = n/1000;//千位
a[1] = (n/100)%10;//百位
a[2] = (n%100)/10;//十位
a[3] = n%10;//个位
if(a[0])
{
if((a[0] ==a[3])&&(a[1] ==a[2]))
return 1;
else
return 0;

}
else if((a[0]==0)&&a[1])
{
if(a[1]==a[3])
return 1;
else
return 0;

}
else if((a[0]==0)&&(a[1]==0)&&a[2])
{
if(a[2]==a[3])
return 1;
else
return 0;

}
else
return 0;

}本回答被网友采纳
第2个回答  2012-03-29
回文数 是什么数呀?

...判断一个数是否为回文数。要用函数fun(int n)来实现。
long re(int a){ long int t;for(t=0;a>0;a\/=10)\/\/将整数反序 t=t*10+a%10;return t;} int nonre(lint n)\/\/判断给定的整数是否为回文数 { if(n>10 && n<2000){ if(re(n)==n)return 1;\/\/是返回1 else return 0;\/\/不是返回0 } return 0;\/\/不是返回0 } void mai...

c++:编一函数int f(int n),功能为判断一个整数n是否为回文数
\/\/参考代码如下:#include <stdio.h>int f(int n)\/\/判断是否是回文数,是返回1,否则返回0{int t=0,m=n;while(m)\/\/如果m不等于0,执行下面循环,否则跳出循环 (求这个数各位上数字反向排列的数 ) {t*=10;t+=m%10;m\/=10;}return t==n;\/\/如果这个数各位数字反向排列所得数依然等...

用C++,如何判断某个数是不是回文数?
1、打开Visual Studio软件,准备好一个新的空白cpp文件,用于稍后编写代码:2、这里定义一个名为palindrome的函数,用来处理判断回文的过程,判断的大致思路就是将一个数反着排列一遍,如果和原先的数一样,那么就是回文数,排列过程用到了余数和整除:3、最后保存一下文件,按住crtl+F5运行程序查看结果,...

求10-200之间所有的回文数,要求每行输出5个。 要求:回文数的判断过程用...
sum\/=10;return bFlag=num==sum?1:0; \/\/返回值的判断我使用三元运算符 } void main(){ int i,count=0;cout<<"10到200之间的回文数有:"<<endl;for(i=10;i<=200;i++){ if(isHuiWen(i)==1){ count++;if(count%5==0||count==19){\/\/经过测试,只有19个数,所以换行的判断...

C++语言 输入一个正整数,判断它是否是回文数
h> int main(){ int num,k,n=0;printf("请输入一个数:");scanf("%d",&num);k=num;while(k>0){ n=n*10+k%10;k=k/10;} if(n==num)printf("%d是回文数",n);else printf("No!它不是回文数!");return0;} 运行效果:...

c++编程 求回文数
k \/= 10;} if(n == revn)return n;} int main(){ int n;for ( n = 1000; n < 10000; n++)cout << huiwen(n) << endl;return 0;} 你思路大体对 但是错误比较多 对照下我写的 主要错误在于 你的m没有赋初值, n每次while都会变,最后为0.不可能与m相等 对照我修改的。不懂...

C++程序,判断一个数是否为回文数
int array[10];\/\/将每个数分解 cout<<"请输入一个数"<<endl;cin>>m;while(m){ array[i++]=m%10;m\/=10;} i--;\/\/while中的多自加了一个 while(i>j){ if(array[j++]!=array[i--])\/\/首位递增,末位递减,直到首位不再小于末位 break;} if(j>i)cout<<"是回文数"<<endl;el...

C++怎么编写一个程序来判断一个整数是否为回文数?
bool palindrome(char *str){ int h=strlen(str);for(int i=0;i<h\/2;i++){ if(str[i]!=str[h-i-1]){ return false;} return true;} } int main(){ char text[180];cout<<"请输入: ";cin>>text;if(palindrome(text))cout<<"这是一个回文!"<<endl;else cout<<"这不是...

求10到10000有哪些回文数?用C语言编写 并且用数组
void main(){ int num,temp1,temp2,count1=0,count2=0;vector<int>test;for(num=10;num<=10000;num++) \/\/找10-10000的回文数 { if(num<100){ temp1=num%10;temp2=num\/10;if(temp1==temp2){ \/\/cout<<num<<" ";printf("%d ",num);count1++;if(count1>=10)\/\/十个一行输出 ...

C++ 输出20-2000所范围内有的回文数
intmain(){intpalindrome=0,reverse=0;intnum=0,key=0,i=0,j=0,count=0;cout<<""<<endl;for(j=10;j<=2000;j++){ reverse=0;key=j;palindrome=j;for(i=1;palindrome!=0;i++){ num=palindrome%10;palindrome=palindrome\/10;reverse=num+(reverse*10);...

相似回答