P1015 回文数

P1015 回文数

题目描述

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

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

又如:对于10进制数87:

STEP1:87+78 = 165 STEP2:165+561 = 726

STEP3:726+627 = 1353 STEP4:1353+3531 = 4884

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

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

输入输出格式

输入格式:

两行,分别是N,M。

输出格式:

STEP=ans

输入输出样例

输入样例#1:

10
87

输出样例#1:

STEP=4

思路:

  运用学习高精度加法时的思想 用字符串来存储数据 然后进行字符串的加法,在比较的时候注意判断 判断不成立ans++ 一直到30或者判断成功输出

#include<cstdio>
#include<string>
#include<iostream>
#include<algorithm>
using namespace std;

const int maxn = 1005;
int a[maxn],N;

void in(int a[]) {
    string str;
    cin>>N>>str;
    a[0] = str.length();
    for(int i = 1; i <= a[0]; i++) {
        if(str[a[0] - i] >= ‘0‘ && str[a[0] - i] <= ‘9‘) a[i] = str[a[0] - i] - ‘0‘;
        else a[i] = str[a[0] - i] - ‘A‘ + 10;
    }
}

inline bool check(int a[]) {
    for(int i=1; i<=a[0]; i++)
        if(a[i]!=a[a[0]-i+1]) return false;
    return true;
}

inline void Plus(int a[]) {
    int b[maxn];
    for(int i=1; i<=a[0]; i++) b[i]=a[a[0]-i+1];
    for(int i=1; i<=a[0]; i++) a[i]+=b[i];
    for(int i=1; i<=a[0]; i++) {
        a[i+1]+=a[i]/N;
        a[i]%=N;
    }
    while(a[a[0]+1]>0) a[0]++;
    return;
}
int main() {
    in(a);
    if(check(a)) {
        cout<<"STEP=0";
        return 0;
    }
    int ans=0;
    while(ans<=30) {
        ans++;
        Plus(a);
        if(check(a)) {
            cout<<"STEP="<<ans;
            return 0;
        }
    }
    cout<<"Impossible!";
    return 0;
}

回文数

自己选的路,跪着也要走完!!!

时间: 2024-12-09 00:48:53

P1015 回文数的相关文章

洛谷 P1015 回文数

P1015 回文数 标签 字符串 模拟 NOIp普及组 1999 云端 难度 普及- 时空限制 1s / 128MB 题目描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个10进制数56,将56加65(即把56从右向左读),得到121是一个回文数. 又如:对于10进制数87: STEP1:87+78 = 165 STEP2:165+561 = 726 STEP3:726+627 = 1353 STEP4:1353+3531 = 4884 在这里的一

洛谷 P1015 回文数 Label:续命模拟QAQ

题目描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个10进制数56,将56加65(即把56从右向左读),得到121是一个回文数. 又如:对于10进制数87: STEP1:87+78 = 165 STEP2:165+561 = 726 STEP3:726+627 = 1353 STEP4:1353+3531 = 4884 在这里的一步是指进行了一次N进制的加法,上例最少用了4步得到回文数4884. 写一个程序,给定一个N(2<=N<=10,N=1

[luogu p1015] 回文数

传送门 题面 题面描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个十进制数\(56\),将\(56\)加\(65\)(即把\(56\)从右向左读),得到\(121\)是一个回文数. 又如:对于十进制数\(87\): STEP1:\(87+78 = 165\) STEP2:\(165+561 = 726\) STEP3:\(726+627 = 1353\) STEP4:\(1353+3531\) = \(4884\) 在这里的一步是指进行了一次\(

判断一个数是否为回文数

#include <stdio.h> int is_palindromic(int num) {  char _old = num;  char _new = 0;  while (num)  {   _new = _new * 10 + (num % 10);   num = num / 10;  }  if (_new == _old)  {   return 1;  }  else  {   return 0;  } } int main() {  int num = 0;  scanf

LeetCode 9 Palindrome Number (回文数)

翻译 确定一个整数是否是回文数.不能使用额外的空间. 一些提示: 负数能不能是回文数呢?(比如,-1) 如果你想将整数转换成字符串,但要注意限制使用额外的空间. 你也可以考虑翻转一个整数. 然而,如果你已经解决了问题"翻转整数(译者注:LeetCode 第七题), 那么你应该知道翻转的整数可能会造成溢出. 你将如何处理这种情况? 这是一个解决该问题更通用的方法. 原文 Determine whether an integer is a palindrome. Do this without ex

要求循环输入一个数,判断是否为回文数

import java.util.Scanner; public class HuiWenShu { public static void main(String[] args) { Scanner input = new Scanner(System.in); char c = 'y'; //初始化c为y,为下面的循环做好准备 while(c == 'y'){ while(c == 'y'){ System.out.println("请随意输入一个大于三位的奇位数"); //回文数属

回文数 第N个回文数

判断回文数还是不难,如果能转为字符串就更简单了. 如果是求第N个回文数呢. 12321是一个回文数,这里先考虑一半的情况. 回文数的个数其实是有规律的.如: 1位回文数: 9个 2位回文数: 9个 3位回文数: 90个 4位回文数: 90个 5位回文数: 900个 6位回文数: 900个 … 我们看到9.90.900,是不是很有规律,那是什么原因?很简单,我们把回文数拆开两半 [123321]来看.两半的变化一样的,那我们只算其中一半就行了.首位不能是0,所以左半最小为 100,最大为999,共

Palindrome Number (回文数)

回文数是指这样的数字:正读和倒读都是一样的.如:595,2332都是回文数,234不是回文数. 注意:负数不是回文数 Determine whether an integer is a palindrome. Do this without extra space. Some hints: Could negative integers be palindromes? (ie, -1) If you are thinking of converting the integer to string

洛谷 P1207 [USACO1.2]双重回文数 Dual Palindromes

题目描述 如果一个数从左往右读和从右往左读都是一样,那么这个数就叫做"回文数".例如,12321就是一个回文数,而77778就不是.当然,回文数的首和尾都应是非零的,因此0220就不是回文数. 事实上,有一些数(如21),在十进制时不是回文数,但在其它进制(如二进制时为10101)时就是回文数. 编一个程序,从文件读入两个十进制数N (1 <= N <= 15)S (0 < S < 10000)然后找出前N个满足大于S且在两种或两种以上进制(二进制至十进制)上是