用 C++ 统计 1 到 N 之间既是完全平方数又是完全立方数的数字个数
给定一个数字 N。目标是统计 1 到 N 之间既是完全平方数又是完全立方数的数字个数。例如,1、64 既是完全平方数又是完全立方数。
我们将使用 sqrt() 计算数字的平方根,并使用 cbrt() 计算数字的立方根。
让我们通过示例来理解。
输入 - N=100
输出 - 既是完全平方数又是完全立方数的数字个数 - 2
解释 - 1 和 64 是 1 到 100 之间唯一既是完全平方数又是完全立方数的数字。
输入 - N=5000
输出 - 既是完全平方数又是完全立方数的数字个数 - 3
解释 - 1、64 和 4096 是 1 到 5000 之间唯一既是完全平方数又是完全立方数的数字。
下面程序中使用的方案如下
我们取一个整数 N。
函数 getCount(int n) 获取 N 并返回 1 到 N 之间既是完全平方数又是完全立方数的数字个数。
将初始计数设为 0。
从 i=1 到 i=N 开始,如果 floor(sqrt(i))==ceil(sqrt(i)),则 i 是一个完全平方数。
现在检查 floor(cbrt(i))==ceil(cbrt(i)) 是否为真,如果为真,则 i 也是一个完全立方数。递增计数。
在循环结束时,返回计数作为结果。
示例
#include <bits/stdc++.h>
#include <math.h>
using namespace std;
int getCount(int n){
int count=0;
for(int i=1;i<=n;i++){
if(floor(sqrt(i))==ceil(sqrt(i))){
if(floor(cbrt(i))==ceil(cbrt(i))){
count++;
//cout<<i<<" ";
}
}
}
return count;
}
int main(){
int N=100;
cout<<endl<<"Numbers upto N that are perfect squares and perfect cubes:"<<getCount(N);
return 0;
}输出
如果我们运行以上代码,它将生成以下输出:
Numbers upto N that are perfect squares and perfect cubes:2
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP