POJ百练 2018研究生上机测试A(回文数)

本文介绍了一个通过编程实现的算法,该算法用于计算给定范围内整数经过特定转换后变为单字符长度的过程中的回文数个数。通过两次转换机会,每个数会被转换为它们各个数字相加的总和,若总和为回文数,则继续转换直到变成单个数字,最终统计成功转化为单个数字的回文数的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结束后不能在线评测。欢迎指正。

#include<cstdio>
#include<stdio.h>
#include<cstdlib>

#include<sstream>
#include<iostream>
#include<string>
#include<cstring>

#include<algorithm>
#include<vector>
#include<stack>
#include<queue>

#include<cmath>

using namespace std;
int main(){
	int k;
	cin>>k;
	int count=0,m;
	for(int i=0;i<k;++i){
		cin>>m;
		string str;
	    stringstream ss;//任意两种类型之间的转换 
	    ss << m;
	    ss >> str;//或者 str = ss.str();
		
		int len=str.size();
		int n=2; 
		while(n-->0){
			int j;
			for(j=0;j<len/2;++j){//判断回文数 
				if(str[j]!=str[len-1-j]){
					break;
				}
			}
			
			if(j<len/2){
				break;
			}
			else{
				int sum=0;
				for(j=0;j<len;++j){
					//const char* c=&str[j];
					//sum+=atoi(c);//从c开始的字符串转成数字
					sum+=str[j]-48;
				}
				m=sum;
				stringstream ss;
				ss << m;
	    		ss >> str;
				len=str.size();
				//cout<<len<<endl;////
				//getchar();///////
			}
		}
		if(len>1){
			continue;//判断下一个数 
		}
		else{
			++count;
		}
	}
	cout<<count;
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值