农夫山姆(0006)
2023-12-22 01:13:09
题意
原来体积是ABC,现在体积是(A-1)* (B-2)*(C-2),输入一个现在的体积n,要求现在的体积比原来减少了多少,输出一个减小的最小值和最大值
输入
4
输出
28 41
说明
注意问题的答案可能足够大,所以必须使用 64 位整数类型进行计算。 请不要使用 %lld 说明符在 С++ 中读取或写入 64 位整数。 最好使用 cin、cout 流或 %I64d 说明符。
代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL n,k,s=9e18+10,cnt,a[1000010];
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n;
for(int i=1;i*i<=n;i++) if(n%i==0) a[cnt++]=i,a[cnt++]=n/i;
if(sqrt(n)==trunc(sqrt(n))) cnt--;
for(int i=0;i<cnt;i++)
{
for(int j=0;j<cnt;j++)
{
if(a[i]*a[j]*(n/a[i]/a[j])==n)
{
s=min(s,(a[i]+1)*(a[j]+2)*(n/a[i]/a[j]+2));
k=max(k,(a[i]+1)*(a[j]+2)*(n/a[i]/a[j]+2));
}
}
}
cout<<s-n<<" "<<k-n<<endl;
return 0;
}
总结
1.trunc函数
表示的是去掉小数点后面的数字,这里使用是因为如果是一个数字的平方的话,因子存了两次,其实是没有影响的,不过也算是一个小优化
2.cnt的增加问题
我们的cnt从0开始使用,
cnt++;
//假设存了两个数字,但是这个时候cnt变成了3
//我们在后面使用的时候,只遍历到cnt-1即可
3.按照题目模拟出结果即可
4.能用大的数据范围就使用大的数据范围
文章来源:https://blog.csdn.net/L3102250566/article/details/135141683
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!