C語(yǔ)言完全平方整數(shù)的判斷
一、原理:
利用 sqrt -- 求平方根 函數(shù)實(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)或負(fù)數(shù),返回值NaN。
三、分析:
sqrt函數(shù)返回值為一個(gè)浮點(diǎn)型數(shù),我們將完全平方整數(shù)傳入該函數(shù)其返回值應(yīng)為該數(shù)平方根的浮點(diǎn)型,將返回值強(qiáng)制轉(zhuǎn)換成整型其值應(yīng)等于本身,而我們將非完全平方整數(shù)傳入該函數(shù)其返回值也應(yīng)為該數(shù)平方根的浮點(diǎn)型,但將返回值強(qiáng)制轉(zhuǎn)換成整型其值應(yīng)不等于本身,利用這一點(diǎn)我們實(shí)現(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; }
? ? ? ??運(yùn)行結(jié)果:
四、舉例:
編寫(xiě)一個(gè)函數(shù),利用參數(shù)傳入一個(gè)3位數(shù)number,找出101~number之間所有滿足下列兩個(gè)條件的數(shù):它是完全平方數(shù),又有兩位數(shù)字相同,如144、676等,函數(shù)返回找出這樣的數(shù)據(jù)的個(gè)數(shù)。請(qǐng)同時(shí)編寫(xiě)主函數(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語(yǔ)言完全平方整數(shù)的判斷的文章就介紹到這了,更多相關(guān)C語(yǔ)言平方整數(shù)判斷內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C語(yǔ)言中條件判斷語(yǔ)句if和switch的用法
這篇文章主要介紹了詳解C語(yǔ)言中條件判斷語(yǔ)句if和switch的用法,是C語(yǔ)言入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-04-04C/C++實(shí)現(xiàn)string和int相互轉(zhuǎn)換的常用方法總結(jié)
在C++編程中,經(jīng)常需要在字符串(string)和整型(int)之間進(jìn)行轉(zhuǎn)換,本文將詳細(xì)介紹幾種在C和C++中實(shí)現(xiàn)這兩種類(lèi)型轉(zhuǎn)換的常用方法,有需要的可以參考下2024-01-01C/C++ Socket設(shè)置接收超時(shí)時(shí)間的多種方法
網(wǎng)絡(luò)編程中經(jīng)常需要處理的一個(gè)問(wèn)題就是如何正確地處理Socket超時(shí),對(duì)于C/C++,有幾種常用的技術(shù)可以用來(lái)設(shè)置Socket接收超時(shí)時(shí)間,在這篇文章中,我們將詳細(xì)介紹如何在C/C++中設(shè)置Socket的非阻塞模式以及如何配置接收超時(shí)時(shí)間,需要的朋友可以參考下2024-01-01C++ 中消息隊(duì)列函數(shù)實(shí)例詳解
這篇文章主要介紹了C++ 中消息隊(duì)列函數(shù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06Linux下g++編譯與使用靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)的方法
下面小編就為大家?guī)?lái)一篇Linux下g++編譯與使用靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05C++ 基礎(chǔ)編程之十進(jìn)制轉(zhuǎn)換為任意進(jìn)制及操作符重載
這篇文章主要介紹了C++ 基礎(chǔ)編程之十進(jìn)制轉(zhuǎn)換為任意進(jìn)制及操作符重載的相關(guān)資料,需要的朋友可以參考下2017-02-02C++實(shí)現(xiàn)二叉樹(shù)非遞歸遍歷方法實(shí)例總結(jié)
這篇文章主要介紹了C++實(shí)現(xiàn)二叉樹(shù)非遞歸遍歷方法實(shí)例總結(jié),是算法設(shè)計(jì)中比較經(jīng)典的一個(gè)遍歷算法,需要的朋友可以參考下2014-08-08