結果
問題 | No.2479 Sum of Squares |
ユーザー |
|
提出日時 | 2023-09-24 23:11:00 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
AC
|
実行時間 | 25 ms / 2,000 ms |
コード長 | 1,006 bytes |
コンパイル時間 | 1,939 ms |
コンパイル使用メモリ | 116,588 KB |
実行使用メモリ | 18,048 KB |
最終ジャッジ日時 | 2024-07-17 23:30:28 |
合計ジャッジ時間 | 2,879 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System; using static System.Console; using System.Linq; using System.Collections.Generic; class Program { static int NN => int.Parse(ReadLine()); static long[] NList => ReadLine().Split().Select(long.Parse).ToArray(); static long[][] NArr(long n) => Enumerable.Repeat(0, (int)n).Select(_ => NList).ToArray(); public static void Main() { Solve(); } static void Solve() { var s = long.Parse(ReadLine()); var ans = new List<long>(); while (s > 0) { var sq = Square(s); ans.Add(sq); s -= sq; } WriteLine(ans.Count); WriteLine(string.Join(" ", ans)); } static long Square(long s) { var ok = 1L; var ng = 1_000_000_001L; while (ng - ok > 1) { var mid = (ok + ng) / 2; if (mid * mid <= s) ok = mid; else ng = mid; } return ok * ok; } }