1.题目

  如标题,求大于整数N(N>=0)的第一个回文数的字符串表示形式。

  这个题目也是当时笔试第一次见到,花了一个小时才做出了。慢慢总结还是挺简单的。

2.分析

  分析如下:

  (1)一位数N(9除外)。

    第一个大于N回文数等于N+1,如大于3的第一个回文数是4。

   

  (2)奇数位(一位数除外)

    需要看“左边反转数字”是否大于"右边数字"

     1)如果小于等于,则“左边+中间字母”组成的数字+1,再对称就可以。

     2)如果大于,则左边数字直接对称到右边就可以啦。

    

  (3)偶数位

    需要看“左边反转数字”是否大于"右边数字"

     1)如果小于等于,则“左边”组成的数字+1,再对称就可以。

     2)如果大于,则左边数字直接对称到右边就可以啦。

    

  (4)特殊情况(其实就一种)

    1)N=9,大于N的下一个回文数是11,即N+2

    2)奇数情况(位数!=1)。

      N1=99900,右边数字小于“左边,翻转数字”,直接对称,所以大于N1的第一个回文数是99999。(满足上面的讨论规则)

      N2=99999,右边数组大于等于“左边,翻转数字”,使用上面的讨论规则结果为1000 001 ,不正确。结果应该是N2+2

    3)偶数情况。

      N1=9900,右边数字小于“左边翻转数字”,直接对称,所以大于N1的第一个回文数是9999。(满足上面的讨论规则)

      N2=9999,右边数组大于等于“左边翻转数字”,使用上面的讨论规则结果为100 001 ,不正确。结果应该是N2+2

  所以,可以将特殊情况归结为一种,当整数N满足正则表达式"9+"时,大于N的第一个回文数是N+2。(9,99,999,9999,.....)

3.生成代码+测试代码

 /**
* 生成函数:
* firstBiggerPalindrome(String n)
* isLeftReverseBiggerRight(String left, String right)
* 后期使用for循环校验N in [0,1000000)时的情况函数:
* nextPalindromeUseFor(int num, boolean[] Palindrome)
* isPalindrome(int num)
*
* 在main函数内进行算法生成 与 for循环暴力生成的校验
* */ public class Solution {
static String firstBiggerPalindrome(String n) { // 生成大于整数N(字符串表示)的第一个回文整数
n = String.valueOf(Integer.parseInt(n)); // 避免前导符"0",如n="009"
if (n.matches("9+")) // 特殊情况直接处理
return String.valueOf(Integer.parseInt(n) + 2); int len = n.length();
if (len == 1) // 长度为1
return String.valueOf(Integer.parseInt(n) + 1);
StringBuilder left = new StringBuilder(); // 左边
StringBuilder right = new StringBuilder(); // 右边
StringBuilder res = new StringBuilder(); // 结果
if ((len & 0x1) == 1) { // 奇数位
left.append(n.substring(0, len >> 1));
right.append(n.substring((len >> 1) + 1));
if (isLeftReverseBiggerRight(left.toString(), right.toString())) { // 如果左边翻转数字大于右边,直接翻转
res.append(left);
res.append(n.charAt(len >> 1));
res.append(left.reverse().toString());
} else { // 否则,“左边+中间”数字加1,再翻转
left.append(n.charAt(len >> 1));
int num = Integer.parseInt(left.toString()) + 1;
left.setLength(0);
left.append(num); res.append(num);
res.append(left.deleteCharAt(left.length() - 1).reverse()
.toString());
}
} else { // 偶数为
left.append(n.substring(0, len >> 1));
right.append(n.substring(len >> 1));
if (!isLeftReverseBiggerRight(left.toString(), right.toString())) {
int num = Integer.parseInt(left.toString()) + 1;
left.setLength(0);
left.append(num);
}
res.append(left.toString());
res.append(left.reverse().toString());
}
return res.toString();
} static boolean isLeftReverseBiggerRight(String left, String right) { // 比较左边翻转后数字与右边数字的大小关系
StringBuilder sb = new StringBuilder(left);
if (sb.reverse().toString().compareTo(right) > 0)
return true;
return false;
} static String nextPalindromeUseFor(int num, boolean[] Palindrome) { // 求大于num的第一个回文数(最后的测试代码使用)
for (int i = num + 1; i < Palindrome.length; i++) {
if (Palindrome[i] == true)
return String.valueOf(i);
}
return null;
} static boolean isPalindrome(int num) { // 判断一个数字是不是回文数字(最后的测试代码使用)
String str = String.valueOf(num);
int i = 0;
int j = str.length() - 1;
while (i < j) {
if (str.charAt(i) != str.charAt(j))
return false;
i++;
j--;
}
return true;
} public static void main(String[] args) throws IOException {
int n = 1000000; // 只测试[0,1000000)以内的结果
boolean[] Palindrome = new boolean[n]; //默认为false
for (int i = 0; i < n; i++) {
if (isPalindrome(i))
Palindrome[i] = true; //如果是回文数字,标记为true。编译下一步校验,大于N的第一个回文数字
} for (int i = 0; i < n; i++) {
String val = firstBiggerPalindrome(String.valueOf(i)); //程序生成
if (Integer.parseInt(val) < n) { //如果在[0,1000000)内,进行校验
if (!val.equals(nextPalindromeUseFor(i, Palindrome)))
System.out.println("BAD\t" + i);
}
}
}
}

通过代码中的验证程序,可以验证算法的正确性,呵呵,nice!!!

Java编程小细节:

  这个题目是字符串处理的,所以用了StringBuilder的reverse();注意一下

 import java.io.*;

 public class Solution {
public static void main(String[] args) throws IOException {
StringBuilder sb = new StringBuilder();
sb.append("liuliuliu");
System.out.println(sb.toString());
sb.reverse(); //不需要返回值,也能翻转,记住啊!!!
System.out.println(sb.toString());
}
}

[2014亚马逊amazon] 在线笔试题 大于非负整数N的第一个回文数 Symmetric Number的更多相关文章

  1. 在亚马逊amazon的AWS上安装Node和MongoDB服务器

    在亚马逊amazon的AWS上安装Node和MongoDB服务器 在建立AWS上账号.创建EC2 ,用putty链接上之后,就可以用下面的方法开始安装. !!! 如果不是是自己建立的EC2, 而是由B ...

  2. 亚马逊AWS在线系列讲座——基于AWS云平台的高可用应用设计

    设计高可用的应用是架构师的一个重要目标,可是基于云计算平台设计高可用应用与基于传统平台的设计有很多不同.云计算在给架构师带来了很多新的设计挑战的时候,也给带来了很多新的设计理念和可用的服务.怎样在设计 ...

  3. 通过SecureCRT访问亚马逊Amazon EC2主机

    亚马逊推出了免费的云主机服务器 Amazon EC2,它是通过安全密钥来访问主机的. 问题是下载的密钥在SecureCRT 上无法直接使用,需要转换. 下面的方法可以在自己的linux主机上生成sec ...

  4. 亚马逊 amazon connect(呼叫中心)

    背景 公司为提高客服部门沟通效率对接电话呼叫中心,调研后选择了亚马逊的Amazon Connect服务,因为是国外业务没有选择用阿里云,怕有坑. Amazon Connect后台 需要在后台创建“联系 ...

  5. 2014阿里巴巴WEB前端实习生在线笔试题

    2014年3月31日晚,我怀着稍微忐忑的心情(第一次在线笔试^_^!!)进行了笔试.阿里巴巴的笔试题共同拥有10道,差点儿包括了Web前端开发的各个方面,有程序题.有叙述题.时间很紧张,仅仅完毕了大概 ...

  6. 2014亚马逊在线笔试题目及解决方案(MMChess问题)

    整体思路:关键是需要知道当前Steps数组中的全排列即可,而且需要不重复的全排列.即关键在于非递归的全排列实现即可~ 其实直接利用STL中的next_permutation算法的,这里我又自己实现了一 ...

  7. U盘版Windows 10已经在亚马逊Amazon開始接受预订啦

    Windows 10定于下周7月29日正式公布. Windows 10家庭版119美元.专业版199美元,这个价格包含 Windows 10 授权.

  8. 亚马逊与Twitter携手电子商务

    亚马逊(Amazon)与Twitter开展了合作,允许用户以Twitter消息的形式将喜欢的商品发送到购物篮中.这些高科技企业正在想办法把社交媒体和电子商务融为一体. 这一功能旨在将Twitter转变 ...

  9. 亚马逊AWS业务副总裁:如何在基础设施上降成本

    腾讯科技 林靖东 11月17日编译 亚马逊Amazon Web Services业务的副总裁.著名工程师詹姆斯汉密尔顿(James Hamilton)在AWS re:Invent大会上解释了公司是如何 ...

随机推荐

  1. Javascript数据类型转换规则

    前言 Javascript有7种数据类型,包括5种原始类型(也叫原始值)number.Boolean.string.null.undefined和2种复合类型object.array,它们之间可以根据 ...

  2. poj-1459-最大流dinic+链式前向星-isap+bfs+stack

    title: poj-1459-最大流dinic+链式前向星-isap+bfs+stack date: 2018-11-22 20:57:54 tags: acm 刷题 categories: ACM ...

  3. STL中优先队列的使用

    普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先删除.优先队列具有最高级先出的行为特征.我们来说一下C++的 ...

  4. 【转】NHibernate对象以及状态说明

    对象 ISessionFactory (NHibernate.ISessionFactory) 针对单个数据库映射关系经过编译后的内存镜像,是线程安全的(不可变). 它是生成ISession的工厂,本 ...

  5. Ubuntu 16.04实现SSH无密码登录/免密登录/自动登录(ssh-keygen/ssh-copy-id)

    ssh-keygen:产生公钥与私钥(在~/.ssh) ssh-copy-id:将本机的公钥复制到远程机器的authorized_keys文件中(在~/.ssh),ssh-copy-id也能让你有到远 ...

  6. WebConfig 加密解密的原理是什么?

    WebConfig 加密解密的原理是什么? 使用命令 加密数据连接串 加密:aspnet_regiis -pef connectionStrings d:/...(webconfig所在路径,不能含中 ...

  7. [Go] Http / Net 相关资料

    [astaxie] [基础]GO搭建一个简单的Web服务器 [astaxie] Go如何使得Web工作 [astaxie] Go 的 Http 包详解 [叶剑峰] Go语言_HTTP包 [叶剑峰] 使 ...

  8. 【防火墙技术连载11】强叔侃墙 攻击防范篇 流量型攻击之UDP Flood及防御

    http://support.huawei.com/huaweiconnect/enterprise/thread-214141.html

  9. 读写文件:每次读入大文件里的一行、读写.CSV文件

    读文件: 传统的读法.所有读出,按行处理: fp=open("./ps.txt", "r"); alllines=fp.readlines(); fp.clos ...

  10. DELPHI之崩溃地址排错代码查看 转

    http://www.cnblogs.com/enli/archive/2009/01/15/1376540.html 最近研究了一下HOOK技术,想抓取某些游戏的包,因此需要注入DLL,结果老是有异 ...