C語言完全平方整數(shù)的判斷
一、原理:
利用 sqrt -- 求平方根 函數(shù)實現(xiàn)完全平方整數(shù)的判斷。
二、函數(shù)
? ? ? ? ?1.原形:
#include <math.h> ... double sqrt(double x);
? ? ? ? 2.參數(shù):x代表要被求平方根的數(shù)。
????????注意:此文章中x定義為整型。
? ? ? ? 3.返回值:如果函數(shù)調(diào)用成功,返回參數(shù) x 的平方根。
? ? ? ? ? ? ? ?如果傳入x為NaN(Not a Number)或負數(shù),返回值NaN。
三、分析:
sqrt函數(shù)返回值為一個浮點型數(shù),我們將完全平方整數(shù)傳入該函數(shù)其返回值應(yīng)為該數(shù)平方根的浮點型,將返回值強制轉(zhuǎn)換成整型其值應(yīng)等于本身,而我們將非完全平方整數(shù)傳入該函數(shù)其返回值也應(yīng)為該數(shù)平方根的浮點型,但將返回值強制轉(zhuǎn)換成整型其值應(yīng)不等于本身,利用這一點我們實現(xiàn)完全平方整數(shù)的判斷。
????????例如:
#include <stdio.h>
#include <math.h>
int main()
{
int a=4;
printf("%g %d",sqrt(a),(int)sqrt(a));
putchar('\n');
int b=3;
printf("%g %d",sqrt(b),(int)sqrt(b));
return 0;
}
? ? ? ??運行結(jié)果:

四、舉例:
編寫一個函數(shù),利用參數(shù)傳入一個3位數(shù)number,找出101~number之間所有滿足下列兩個條件的數(shù):它是完全平方數(shù),又有兩位數(shù)字相同,如144、676等,函數(shù)返回找出這樣的數(shù)據(jù)的個數(shù)。請同時編寫主函數(shù)。
#include <stdio.h>
#include <math.h>
int func(int);
int func(int x)
{
int i;
int count=0;
int t1,t2,t3;
for(i=101;i<=x;i++)
{
if(sqrt(i)==(int)sqrt(i))
{
t1=i%10;
t2=i/10%10;
t3=i/100;
if(t1==t2||t2==t3||t1==t3)
count++;
}
}
return count;
}
int main()
{
int x;
scanf("%d",&x);
printf("%d",func(x));
return 0;
}
總結(jié)
到此這篇關(guān)于C語言完全平方整數(shù)的判斷的文章就介紹到這了,更多相關(guān)C語言平方整數(shù)判斷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解VS2019 dumpbin查看DLL的導(dǎo)出函數(shù)
這篇文章主要介紹了詳解VS2019 dumpbin查看DLL的導(dǎo)出函數(shù),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
C# interface與delegate效能比較的深入解析
本篇文章是對C#中interface與delegate的效能比較進行了詳細的分析介紹,需要的朋友參考下2013-05-05
C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù)詳解
這篇文章主要為大家詳細介紹了C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
opencv3/C++ 將圖片轉(zhuǎn)換為視頻的實例
今天小編就為大家分享一篇opencv3/C++ 將圖片轉(zhuǎn)換為視頻的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
stl容器set,map,vector之erase用法與返回值詳細解析
在使用 list、set 或 map遍歷刪除某些元素時可以這樣使用,如下所示2013-09-09
C語言數(shù)據(jù)結(jié)構(gòu)與算法之鏈表(一)
鏈表是線性表的鏈?zhǔn)酱鎯Ψ绞健f湵淼膬?nèi)存是不連續(xù)的,前一個元素存儲地址的下一個地址中存儲的不一定是下一個元素。小編今天就將帶大家深入了解一下鏈表,快來學(xué)習(xí)吧2021-12-12

