关注
#include<set>
#include<iostream>
#include<vector>
using namespace std;
int numSquares(int n)
{//找出n所组成的最小的完全平方个数
while(n%4==0) n/=4;
if(n%8 == 7) return 4;
for(int a = sqrt(n); a > 0; --a)
{
int b = sqrt(n-a*a);
if(a*a+b*b == n) return !b? 1 : 2;
}
return 3;
}
set<int> get_data(int n){//获取每个完全平方数
set<int> data;
for(int i = 0; i<n; ++i){
data.insert(i*i);
}
return data;
}
vector<int> get_out(set<int> data, int n, int m){//遍历,找出符合要求的完全平方数
set<int> ::iterator it = data.begin();
it = data.lower_bound(n);
vector<int> out_o;
int p = m;
while(p--){
--it;
out_o.clear();
set<int> ::iterator it1 = it;
int a,s = 0,s1=0;
while(it1!=data.begin()){
a = *it1;
s += a;
if(s<n){
out_o.push_back(a);
--it1;
}
else if (s>n)
{
s -= a;
--it1;
}
else{
out_o.push_back(a);
break;
}
if(out_o.size()>m)
break;
}
int len = out_o.size();
for(int i = 0; i<len; ++i)
s1 += out_o[i];
if(s1==n && len==m) break;
}
return out_o;
}
int main()
{
int n;
while(cin>>n){
set<int> data;
data = get_data(n);//集合中存放每个与下标对应的完全平方数
int m = numSquares(n);//获取其和为n的最小的完全平方数的个数
int s = 0;
vector<int> out_o = get_out(data, n, m);//得到所求的完全平方数
for(int i = out_o.size()-1; i>=0; --i){
s += out_o[i];
}
if(s==n){
for(int i = out_o.size()-1; i>=0; --i)
cout<<out_o[i]<<" ";
}
else
cout<<"NA";
cout<<endl;
}
return 0;
} 我用了另外一种思路,这种方法既能保证从小到大又能是输出的个数最小,但是方法不是很简便,欢迎有更好思路的小伙伴可以留言评论。
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
10-24 18:54
南京大学 后端工程师 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 摸鱼被leader发现了怎么办 #
73136次浏览 420人参与
# 工作后明白的那些道理 #
29199次浏览 297人参与
# 工作后,你落下了哪些病根 #
1132次浏览 28人参与
# 电网求职进展汇总 #
33339次浏览 90人参与
# 你学到的“最没用”的职场技能是 #
974次浏览 27人参与
# 七夕节你打算怎么过? #
69995次浏览 806人参与
# 国央企笔面经互助 #
172345次浏览 1211人参与
# 业务面应该做哪些准备 #
80309次浏览 830人参与
# 你见过最离谱的招聘要求是什么? #
245391次浏览 1691人参与
# 满帮集团求职进展汇总 #
13229次浏览 95人参与
# 拼多多求职进展汇总 #
797647次浏览 6452人参与
# 上班到公司第一件事做什么? #
113550次浏览 782人参与
# 职场破防瞬间 #
352613次浏览 2827人参与
# 工作两年想退休了 #
207847次浏览 1839人参与
# 国企/银行/研究所公司爆料 #
177587次浏览 889人参与
# 视觉/交互/设计招聘信息汇总 #
24383次浏览 634人参与
# 产品人求职现状 #
299053次浏览 2363人参与
# 如果可以选,你最想从事什么工作 #
672115次浏览 4848人参与
# 满分简历要如何准备? #
249507次浏览 2959人参与
# 通信和硬件还有转码的必要吗 #
80049次浏览 584人参与

腾讯音乐娱乐集团公司福利 285人发布