首页 > 其他分享 >p1015 [NOIP1999 普及组] 回文数

p1015 [NOIP1999 普及组] 回文数

时间:2022-11-28 19:55:42浏览次数:51  
标签:10 reverse string p1015 int NOIP1999 include 回文

[NOIP1999 普及组] 回文数

题目描述

若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数。

例如:给定一个十进制数 \(56\),将 \(56\) 加 \(65\)(即把 \(56\) 从右向左读),得到 \(121\) 是一个回文数。

又如:对于十进制数 \(87\):

STEP1:\(87+78=165\)
STEP2:\(165+561=726\)
STEP3:\(726+627=1353\)
STEP4:\(1353+3531=4884\)

在这里的一步是指进行了一次 \(N\) 进制的加法,上例最少用了 \(4\) 步得到回文数 \(4884\)。

写一个程序,给定一个 \(N\)(\(2 \le N \le 10\) 或 \(N=16\))进制数 \(M\)(\(100\) 位之内),求最少经过几步可以得到回文数。如果在 \(30\) 步以内(包含 \(30\) 步)不可能得到回文数,则输出 Impossible!

输入格式

两行,分别是 \(N\),\(M\)。

输出格式

如果能在 \(30\) 步以内得到回文数,输出格式形如 STEP=ans,其中 \(\text{ans}\) 为最少得到回文数的步数。

否则输出 Impossible!

样例 #1

样例输入 #1

10
87

样例输出 #1

STEP=4

思路

首先要考虑是否为回文数,所谓回文数就是将自己倒转和原来的相同。那么有一个函数reverse()完美符合我们的需求,它的作用就是将一个字符串倒转过来。那么我们可以写判断是否为回文数的func:

bool isdrome(string a){
    string b=a;
    reverse(b.begin(),b.end());
    return a==b;
}

再回看题目,它需要将自己与自己的回文数加起来,由于我们处理的是字符串,因此我们需要把它转换成整型再进行相加,同时我们也要考虑相加后的进位问题:

string add(string a){
    string b=a;
    reverse(b.begin(),b.end());
    int x,y,t=0,len=a.size();
    for(int i=len-1;i>=0;i--){
        x=(a[i]>='A')?(a[i]-'A'+10):(a[i]-'0');
        y=(b[i]>='A')?(b[i]-'A'+10):(b[i]-'0');
        x+=y+t;//此时是将x+y然后处理进位
        t=(x>=n)?1:0;//进位判断
        if(t==1){
            x-=n;
        }
        a[i]=(x>9)?(x+'A'-10):(x+'0');//复原
    }
    if(t==1){
        a="1"+a;
    }
    return a;
}

完整程序

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<map>
#include<vector>
#include<queue>
#include<set>
#include<unordered_map>
using namespace std;
int n;

string add(string a){
	string b=a;
	reverse(b.begin(),b.end());
	int x,y,t=0,len=a.size();
	for(int i=len-1;i>=0;i--){
		x=(a[i]>='A')?(a[i]-'A'+10):(a[i]-'0');
		y=(b[i]>='A')?(b[i]-'A'+10):(b[i]-'0');
		x+=y+t;
		t=(x>=n)?1:0;
		if(t==1)
			x-=n;
		a[i]=(x>9)?(x+'A'-10):(x+'0');//复原 
	}
	if(t==1)
		a="1"+a;
	return a;
}

bool isdrome(string a){
	string b=a;
	reverse(b.begin(),b.end());
	return a==b;
}

int main(){
	int i;
	string m;
	cin>>n>>m;
	for(i=0;i<=30&&!isdrome(m);i++)
		m=add(m);
	if(i>30)
		cout<<"Impossible!"<<endl; 
	else
		cout<<"STEP="<<i<<endl;
	return 0;
}

标签:10,reverse,string,p1015,int,NOIP1999,include,回文
From: https://www.cnblogs.com/simdow/p/16933421.html

相关文章

  • 算法题-完美的代价--回文串
    算法题-完美的代价--回文串问题描述回文串,是一种特殊的字符串,它从左往右读和从右往左读是一样的。小龙龙认为回文串才是完美的。现在给你一个串,它不一定是回文的,请你......
  • 数学题-长度为5的不同回文子序列
    1930.长度为3的不同回文子序列问题描述给你一个字符串s,返回s中长度为3的不同回文子序列的个数。即便存在多种方法来构建相同的子序列,但相同的子序列只计数一......
  • 回文串判断
    1、直接上代码publicstaticbooleanisPalindrome(Strings){//1、判断字符串是否是null或者是空字符,如果是就返回trueif(s==null&&"".equals......
  • 最长回文串
    最长回文串一、题目描述给定一个包含大写字母和小写的字符串s,返回通过这些字母构成的最长的回文串。在构造过程中,请注意区分大小写。示例1输入:s="abccccdd"输出:7......
  • 返回字符串中的最大回文数
    /***@authorpshdhx*@date2022-08-0315:20*@Des给你一个字符串s,找到s中最长的回文子串。*输入:s="babad"*输出:"bab"*解释:"aba"同样是符合题意的......
  • 回文串
    分割回文串https://leetcode.cn/problems/palindrome-partitioning/classSolution:defdfs(self,s,idx,path):"""idx:当前处理到的第idx个字符"""......
  • vue 项目中,后端返回文件流,导出excel
    之前写过文件流导出excel,这次直接把上次的代码拿过来复制粘贴,但是导出的表格里面没有数据,只显示undefined。这是之前的代码//api接口页面//excel导出接口export......
  • leetcode680-验证回文串 II。方法有缺陷,还需要继续琢磨
    680.验证回文串II这个做法就是利用双指针。一个指向第一个字符,一个指向最后一个字符。遇到两个指针指向的字符相同时,一个往前走,一个往后走。如果遇到不相同,那么就看看......
  • 【XSY3320】【LOJ6681】yww 与树上的回文串(border理论,点分治)
    咕了一年的题。先点分治。考虑某条经过当前重心\(rt\)的合法回文路径:(图摘自yww的题解)其中\(x\toy\)是合法回文路径,那么\(T\)是一个回文串。先把\(rt\)到每......
  • 回文自动机
    回文自动机有些很优秀的性质。广义回文自动机你现在要对多个串建回文自动机,一个一个直接插进回文自动机里是对的。(也就是广义后缀自动机假掉的那种建法)例:LuoguP5555......