Chinaunix首页 | 论坛 | 博客
  • 博客访问: 216727
  • 博文数量: 68
  • 博客积分: 3120
  • 博客等级: 中校
  • 技术积分: 715
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-08 09:53
文章分类
文章存档

2012年(29)

2011年(3)

2010年(18)

2009年(18)

我的朋友

分类: C/C++

2012-01-18 20:01:07

问题:

A palindromic number reads the same both ways. The largest palindrome made from the product of two 2-digit numbers is 9009 = 91 × 99.

Find the largest palindrome made from the product of two 3-digit numbers.

答案: 906609

#include

int reverse(int n)
{
    int reversed = 0;
    while(n>0){
        reversed = 10*reversed + n%10;
        n /= 10;
    }

    return reversed;
}

int isPalindrom(int n)
{
    return n==reverse(n);
}

int main(void)
{
    int largest = 0;
    int a = 999;
    int b = 999;
    int db = 1;

    while(a>=100){
        if((a%11) == 0)
            b = 999, db = 1;
        else
            b = 990, db = 11;

        while(b>=a){
            if(a*b < largest)
                break;
            if(isPalindrom(a*b))
                largest = a*b;
            b -= db;
        }
        a--;
    }

    printf("%d\n", largest);
    return 0;
}



阅读(553) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~