c++:编一函数int f(int n),功能为判断一个整数n是否为回文数

编一函数int f(int n),功能为判断一个整数n是否为回文数(回文是指正读、倒读都一样的数,如121,2332都是回文数),若是,函数的返回值为1,否则为0。在主函数中统计并输出四位正整数中回文数的个数。

//参考代码如下:
#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;//如果这个数各位数字反向排列所得数依然等于该数,该数就是回文数 
}
int main(){
int i,n;
for(i=1000,n=0;i<10000;i++)//计算1000-10000直接的回文数,如果是打印出来 
{
if(f(i)){
printf("%d\n",i);
n++;
}
}
printf("count:%d\n",n);//输出总的回文数 
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-01-01
函数如下:
int f(int n)
{
int a[100] = {0};
int top = -1;

while (n > 0) //提取各位数字
{
a[++top] = n % 10;
n /= 10;
}

int left = 0;
while (left < top)//判断是否回文
{
if (a[left++] != a[top--])
return 0;
}
return 1;
}

完整程序如下:
#include <iostream>
using namespace std;

int f(int n)
{
int a[100] = {0};
int top = -1;

while (n > 0) //提取各位数字
{
a[++top] = n % 10;
n /= 10;
}

int left = 0;
while (left < top)//判断是否回文
{
if (a[left++] != a[top--])
return 0;
}
return 1;
}

int main()
{
int i=0,count=0;

cout<<"四位正整数中回文数有: "<<endl;
for(i=1000;i<10000;i++)
if(f(i))
{
cout<<i<<"\t";
count++;
}

cout<<"共有"<<count<<"个。"<<endl;

return 0;
}
第2个回答  2012-01-01
#include <iostream>
using namespace std;
int f(int n){
int m,t,sum=0;
m=n;
while(m>0){
t=m%10;
sum=sum*10+t;
m/=10;
}
return sum==n;
}

main(){
int i,n=0;
for(i=1000;i<9999;i++)
if(f(i)==1){
n++;
cout << i << ' ';
}
cout << endl;
cout << "整数个数 " << n << endl;
}
sorry,调试了一下追问

不对- -

第3个回答  推荐于2017-11-24
#include <stdio.h>
int f(int n)
{
int t=0,m=n;
while(m)
{
t*=10;
t+=m%10;
m/=10;
}
return t==n;
}
int main(){
int i,n;
for(i=1000,n=0;i<10000;i++)
{
if(f(i)){
printf("%d\n",i);
n++;
}
}
printf("count:%d\n",n);
}本回答被提问者采纳
第4个回答  2012-01-01
#include<stdio.h>
#include<string.h>
int f(int n)
{
char a[32];
int i,n;
sprintf(a,"%d",n);
n=strlen(a);
for(i=0,n-=1;i<=n;i++,n--)
{
if(a[i]!=a[n])
return 0;
}
return 1;
}

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运行程序查看结果,...

...数,判断一个数是否为回文数。要用函数fun(int n)来实现。
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...

C++语言 输入一个正整数,判断它是否是回文数
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++程序,判断一个数是否为回文数
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语言用递归判断数字是否为回文数
首先求出数字的长度n,然后判断第1位和第n位是否相等第i位和第n+1-i位是否相等。对i循环单独写一个函数求出这个数字第i位的大小int GetI(int i,int number){ if(i==1) return number%10; return GetI(i-1,number\/10);} 本回答由提问者推荐 举报| 评论 4 1 ...

C++判定回文数
\/* 功能:判断一个数是不是回文数 参数:iData -- 需要判断的数 返回值:true -- 是回文数; false -- 不是回文数*\/ bool IsStrReverse(int iData){ \/* 取绝对值*\/ iData > 0 ? iData : - iData;\/* 把iData各位输出到buf中*\/ char buf[100];sprintf(buf, "%d", iData);int n...

用c++写一个程序判断一个数是不是回文数
{ if(*(data+i)!=*(data+j)){ f=1; printf("%d 不是回文!!!\\n",x); break;} } if(f==0)printf("%d 是回文 !\\n",x);} separate(int *data,int n){ int j,k,t;y=0;while(n!=0){ (data+y)=n%10; n=n\/10; y++;} (data+y)='\\0';for(j=0,k=y-1; j...

C++怎么编写一个程序来判断一个整数是否为回文数?
using namespace std;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;e...

判断回文数(C++) 输入:一个串数n。 输出:如果是回文数输出“YES”,否 ...
int main(){ int n,i,s=0,a,b,c,d=0,e;cin>>n;a=n;e=n;while(a!=0){ a=a\/10;s++;} for(i=1;i<=s;i++){ a=e%10;b=i+s-i;while(b!=0){ c=a;c=c*10;b--;} d=d+c;e=e\/10;} if(d==n)cout<<"YES";else cout<<"NO";system ("pause");return ...

相似回答