数论 - SGU 107 987654321 problem

 987654321 problem#

Problem's Link
#


 

Mean: 

analyse:

这道题目是道简单题.

不过的确要好好想一下:

通过简单的搜索可以知道,在N<9时答案一定为0,而N=9时有8个解。由于题目只是问“最后9位”,所以N=10的时侯第10位的取值不会对平方和的“最后9位”产生影响,而第10位上有9种取值方法,所以N=10的时侯,答案是72.

同样可以知道,当N>10的时侯,只要在72后加入(N-10)个“0”即可.

Time complexity: O(n)

 

view code

/**
* -----------------------------------------------------------------
* Copyright (c) 2016 crazyacking.All rights reserved.
* -----------------------------------------------------------------
*       Author: crazyacking
*       Date  : 2016-01-06-18.55
*/
#include <queue>
#include <cstdio>
#include <set>
#include <string>
#include <stack>
#include <cmath>
#include <climits>
#include <map>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long(LL);
typedef unsigned long long(ULL);
const double eps(1e-8);

/**
* SGU 107. 987654321 problem
* n < 9: ans = 0.
* n = 9: ans = 8
* n > 9: ans = 8*9*(10^(n-10))
*/

int main(int argc, char **argv)
{
   int n = 0;
   scanf("%d", &n);
   if(n < 9)
       printf("0");
   else if(n == 9)
       printf("8");
   else
   {
       printf("72");
       for(int i = 0; i < n-10; ++i)
           printf("0");
   }
   return 0;
}

 

posted @   北岛知寒  阅读(264)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示
主题色彩