Vijos训练计划 1304回文数

描述

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

例如:给定一个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,其中16进制数字为0-9与A-F,求最少经过几步可以得到回文数。如果在30步以内(包含30步)不可能得到回文数,则输出“Impossible!”

格式

输入格式

共两行
第一行为进制数N(2<=N<=10或N=16)
第二行为N进制数M(0<=M<=maxlongint)

输出格式

共一行
第一行为“STEP=”加上经过的步数或“Impossible!”

样例1

样例输入1

9
87

Copy

样例输出1

STEP=6

Copy

限制

各个测试点1s

来源

NOIP1999提高组第2题

 1 #include <iostream>
 2 #include <string.h>
 3 #include <math.h>
 4 #include <cstdio>
 5 #include <stdlib.h>
 6
 7 using namespace std;
 8
 9 int main()
10 {
11     int n;//n进制数
12     char m[40];
13     int m_n[40]={0},m_rev[40]={0};
14     cin>>n>>m;
15     int l=strlen(m);
16     for(int i=l-1;i>=0;i--)
17     {
18         if(m[i]<=‘9‘&&m[i]>=‘0‘)
19             m_n[i]=m[i]-‘0‘;
20         else
21             m_n[i]=m[i]-‘A‘+10;
22     }
23     int flag=1;
24     for(int i=0;i<=l/2;i++)
25         if(m_n[i]!=m_n[l-i-1])
26         {
27             flag=0;
28             break;
29         }
30     if(flag==1)
31     {
32         cout<<"STEP=0"<<endl;
33         return 0;
34     }
35     int step=0;
36     while(1)
37     {
38         for(int i=l-1;i>=0;i--)
39             m_rev[i]=m_n[l-i-1];
40         int l0=l;
41         for(int i=0;i<=l0-1;i++)
42     {
43         m_n[i]+=m_rev[i];
44         while(m_n[i]>=n)
45         {
46             m_n[i]-=n;
47             m_n[i+1]++;
48             if(i==l-1)
49                 l++;
50         }
51     }
52         step++;
53         int flag=1;
54         for(int i=0;i<=l/2;i++)
55             if(m_n[i]!=m_n[l-i-1])
56             {
57                 flag=0;
58                 break;
59             }
60         if(flag==0&&step>30)
61         {
62             cout<<"Impossible!"<<endl;
63             break;
64         }
65         else if(flag==1)
66         {
67             printf("STEP=%d\n",step);
68             break;
69         }
70     }
71     return 0;
72 }

因为没加“=”而wa巨多次

因为impossible的I没有大写而wa

题是水题 但细心才能对啊...

原文地址:https://www.cnblogs.com/yalphait/p/8506875.html

时间: 2024-11-10 14:35:43

Vijos训练计划 1304回文数的相关文章

Vijos 回文数

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

判断一个数是否为回文数

#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且在两种或两种以上进制(二进制至十进制)上是

一个5位数,判断它是不是回文数

题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同. 1 package com.li.FiftyAlgorthm; 2 3 import java.util.Scanner; 4 5 /** 6 * 题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同. 7 * @author yejin 8 */ 9 public class Palindrom { 10 public static void main(Strin

习题-四季-回文数-不死神兔

1-键盘录入月份,输出对应的季节.一年有四季;3,4,5春季;6,7,8夏季;9,10,11秋季;12,1,2冬季 public class Demo02Test {     public static void main(String[] args) {         // 键盘录入一个月份,用Scanner实现         Scanner sc = new Scanner(System.in);         // 接收数据         System.out.println("请