`
lmx227
  • 浏览: 52052 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

判断一个数是否是完全平方数

 
阅读更多

利用恒等式: 1+3+5+7+....+(2*n-1)=n^2

bool isSqrt(int n)
{
    for(int i=1;n>0;i+=2) n-=i;
    return 0 == n;
}

下面是一些关于完全平方数的数学性质:

对排除完全平方数有一定的加速作用:

性质1:完全平方数的末位数只能是0,1,4,5,6,9。 
性质2:奇数的平方的个位数字为奇数,十位数字为偶数。 
证明 奇数必为下列五种形式之一: 
10a+1, 10a+3, 10a+5, 10a+7, 10a+9 
分别平方后,得 
(10a+1)^2=100+20a+1=20a(5a+1)+1 
(10a+3)^2=100+60a+9=20a(5a+3)+9 
(10a+5)^2=100+100a+25=20 (5a+5a+1)+5 
(10a+7)^2=100+140a+49=20 (5a+7a+2)+9 
(10a+9)^2=100+180a+81=20 (5a+9a+4)+1 
综上各种情形可知:奇数的平方,个位数字为奇数1,5,9;十位数字为偶数。 
性质3:如果完全平方数的十位数字是奇数,则它的个位数字一定是6;反之,如果完全平方数的个位数字是6,则它的十位数字一定是奇数。 
证明 已知=10k+6,证明k为奇数。因为的个位数为6,所以m的个位数为4或6,于是可设m=10n+4或10n+6。则 
10k+6=(10n+4)=100+(8n+1)x10+6 
或 10k+6=(10n+6)=100+(12n+3)x10+6 
即 k=10+8n+1=2(5+4n)+1 
或 k=10+12n+3=2(5+6n)+3 
∴ k为奇数。 
推论1:如果一个数的十位数字是奇数,而个位数字不是6,那么这个数一定不是完全平方数。 
推论2:如果一个完全平方数的个位数字不是6,则它的十位数字是偶数。 
性质4:偶数的平方是4的倍数;奇数的平方是4的倍数加1。 
这是因为 (2k+1)=4k(k+1)+1 
(2k)=4 
性质5:奇数的平方是8n+1型;偶数的平方为8n或8n+4型。 
在性质4的证明中,由k(k+1)一定为偶数可得到(2k+1)是8n+1型的数;由为奇数或偶数可得(2k)为8n型或8n+4型的数。 
性质6:平方数的形式必为下列两种之一:3k,3k+1。 
因为自然数被3除按余数的不同可以分为三类:3m,3m+1, 3m+2。平方后,分别得 
(3m)=9=3k 
(3m+1)=9+6m+1=3k+1 
(3m+2)=9+12m+4=3k+1 
同理可以得到: 
性质7:不能被5整除的数的平方为5k±1型,能被5整除的数的平方为5k型。 
性质8:平方数的形式具有下列形式之一:16m,16m+1, 16m+4,16m+9。 
除了上面关于个位数,十位数和余数的性质之外,还可研究完全平方数各位数字之和。例如,256它的各位数字相加为2+5+6=13,13叫做256的各位 数字和。如果再把13的各位数字相加:1+3=4,4也可以叫做256的各位数字的和。下面我们提到的一个数的各位数字之和是指把它的各位数字相加,如果 得到的数字之和不是一位数,就把所得的数字再相加,直到成为一位数为止。我们可以得到下面的命题: 
一个数的数字和等于这个数被9除的余数。 
下面以四位数为例来说明这个命题。 
设四位数为,则 
= 1000a+100b+10c+d 
= 999a+99b+9c+(a+b+c+d) 
= 9(111a+11b+c)+(a+b+c+d) 
显然,a+b+c+d是四位数被9除的余数。 
对於n位数,也可以仿此法予以证明。 
关於完全平方数的数字和有下面的性质: 
性质9:完全平方数的数字之和只能是0,1,4,7,9。 
证明 因为一个整数被9除只能是9k,9k±1, 9k±2, 9k±3, 9k±4这几种形式,而 
(9k)=9(9)+0 
(9k±1)=9(9±2k)+1 
(9k±2)=9(9±4k)+4 
(9k±3)=9(9±6k)+9 
(9k±4)=9(9±8k+1)+7 
除了以上几条性质以外,还有下列重要性质: 
性质10:为完全平方数的充要条件是b为完全平方数。 
证明 充分性:设b为平方数,则 
==(ac) 
必要性:若为完全平方数,=,则 
性质11:如果质数p能整除a,但p的平方不能整除a,则a不是完全平方数。 
证明 由题设可知,a有质因数p,但无因数,可知a分解成标准式时,p的次方为1,而完全平方数分解成标准式时,各质因数的次方均为偶数,可见a不是完全平方数。 
性质12:在两个相邻的整数的平方数之间的所有整数都不是完全平方数,即若 
n^2 < k^2 < (n+1)^2 
则k一定不是完全平方数。 
性质13:一个正整数n是完全平方数的充分必要条件是n有奇数个因数(包括1和n本身)。

分享到:
评论

相关推荐

    python判断完全平方数的方法

    判断一个数是否为完全平方数是常见的数学问题,尤其在编程中经常遇到,例如在解决一些算法或数学谜题时。在给定的文件中,作者分享了一种用Python来判断完全平方数的方法。 首先,让我们了解判断完全平方数的基本...

    一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

    这个程序使用循环来遍历所有可能的整数,然后判断每个数是否满足条件,即加上 100 后是一个完全平方数,再加上 168 又是一个完全平方数。 这三个问题都可以使用不同的算法和数据结构来解决,例如排列组合、条件语句...

    完全平方数

    求解完全平方数的一个程序,输入求解区间。

    C语言100例经典算法

    + 数学运算:程序使用平方根运算来判断一个数是否是完全平方数。 + 编程实现:使用C语言实现了平方根运算和if语句来解决问题。 程序4:判断某天是某年的第几天 * 标题:判断某天是某年的第几天 * 描述:输入某年...

    第2课 嵌套循环训练.pdf

    - 首先判断一个数是否是完全平方数,如果是,则对其平方根的每一位数字进行计数。 - 如果计数结果中有数字的数量大于或等于2,则该数是一个特殊完全平方数。 - 对一个数区间内的每一个数进行上述检查,直到找到第...

    蓝桥杯2020年5月青少组Python程序设计国赛真题.pptx

    在Python中,我们可以使用 math 模块的 sqrt 函数来计算平方根,从而判断一个数字是否是完全平方数。例如: ```python import math def is_perfect_square(n): sqrt_n = math.sqrt(n) return sqrt_n == int(sqrt_n...

    C语言经典100题(算法题、程序题)

    程序3展示了如何判断一个数是否是完全平方数。这道题目考察了程序员对数学运算的理解和运用,以及对判断语句的使用。 年月日判断 程序4展示了如何判断一个日期是年份的第几天。这道题目考察了程序员对日期计算的...

    c代码-一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?

    在C语言中,我们可以使用sqrt函数来计算一个数的平方根,并通过比较平方根的整数部分与浮点部分来判断是否为完全平方数。如果平方根的整数部分和浮点部分相等,那么这个数就是完全平方数。 以下是一个简单的C代码...

    Python-100例(DOC95页).doc

    实例3中,使用了`math.sqrt()`函数计算平方根,判断一个数是否是完全平方数。Python的`math`模块提供了许多数学函数,如平方根、指数、对数等。 6. **日期与时间处理**: 实例4展示了如何处理日期并计算天数。...

    C语言编程实例.pdf

    - 程序3中,使用了数学库(math.h)中的平方根函数`sqrt`,来判断一个数是否是完全平方数。这是C语言中对数学函数的调用,同时也涉及到数值比较和条件判断。 7. **循环优化与效率**: - 在程序3中,通过限制循环...

    蓝桥杯Python模拟赛题之数学问题完全平方数.zip

    首先,我们需要了解如何在Python中检查一个数是否为完全平方数。这可以通过计算数的平方根并判断其是否为整数来实现。Python提供了`math`模块,可以方便地进行数学运算。例如: ```python import math def is_...

    c语言编程题之数学问题有效的完全平方数.zip

    在本编程题中,我们需要编写一个程序来判断输入的数字是否为有效的完全平方数。这涉及到数字处理和算法设计,是C语言初学者经常会遇到的练习。 首先,我们要理解完全平方数的特性。一个正整数n如果是完全平方数,...

    寻找完全平方数_C语言_

    在C语言中,寻找完全平方数的基本方法是通过循环遍历数字,然后判断每个数字的平方根是否为整数。这通常涉及到两个核心函数:`sqrt()` 和 `%`(取余运算符)。`sqrt()` 函数是C语言标准库math.h中的一个函数,用于...

    C语言经典编程100例

    一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后 ...输入某年某月某日,判断...

    80个C语言题+答案(源码).rar

    题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,...

Global site tag (gtag.js) - Google Analytics