如何解决如何从文件中输出第一个和最后一个完全平方之间的数字?
我有一个文件(“bac.txt),其中包含数字 11 245 36 67 8 576 11 16 41 144 67 89 1011
(这是未知数量的数字)。
第一个完全正方形是 36,最后一个是 144,我必须输出这 2 个之间的数字,所以输出必须是 36 67 8 576 11 16 41 144
。我设法弄到了最后一个,但不知道如何记住第一个。
#include <iostream>
#include <fstream>
#include <bits/stdc++.h>
using namespace std;
int main()
{
ifstream f("bac.txt");
int n,rp,x;
int first = INT_MAX,last = INT_MAX;
int cnt = 0,cnt2 = 0;
while(f >> n){
rp = sqrt(n);
if(rp * rp == n)
last = n;
if((rp * rp == n) && n < first)
first = n;
}
cout << first << " " << last;
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。