U460226 【第十四届蓝桥杯C++青少组_国赛_中高级组】八进制回文平方数

题目描述

给定一个十进制正整数N(1≤N≤109),请从小到大输出1-N之间(含1和N)所有满足以下要求的数: 1.这个数转换为八进制后是一个回文数; 2.这个数是一个平方数。 例如:N=20,在1~20之间满足要求的数有1、4、9,因为有 1转换为八进制为1,是一个回文数;且1=1^2,是一个平方数 4转换为八进制为4,是一个回文数;且4=2^2,是一个平方数 9转换为八进制为11,是一个回文数;且9=3^2,是一个平方数 故输出1 4 9

输入格式

输入一个十进制正整数N(1≤N≤109)

输出格式

输出一行,包含若干个十进制正整数,表示满足题目要求的数。结果从小到大输出,两个正整数之间用一个空格隔开

说明/提示

八进制数:指逢8进位的一种进位计数制,以0、1、2、3、4、5、6、7共八个数码表示。例如:十进制数8等于八进制数10,十进制数64等于八进制数100,以此类推。 回文数:反向排列与原来一样的数。例如,12321是回文数,1231不是回文数。 平方数:可以写成某个整数的平方的数。例如,9=3^2,9是一个平方数,