题目链接 题意:求化简后的分子之和。 题解:每次先把奇数加上,剩下偶数除以2,继续上面操作知道没有剩下数或是除以2的次数等于k。 下面时AC代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
#define int long long
signed main()
{
int t;
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>t;
while(t--)
{
int n,k;
cin>>n>>k;
int ans=0;
int coun=0;
int x=(1+n)*n/2;
int nn=n;
while(coun<k&&x>0)
{
int kk=x;
if(nn%2==0)
{
ans+=x/(nn+1)*(nn/2);
x=x/(nn+1)*(nn/2+1)/2;
nn/=2;
}
else if(nn%2!=0)
{
ans+=x/nn*(nn/2+1);
x=x/nn*(nn/2)/2;
nn/=2;
}
coun++;
}
cout<<ans+x<<endl;
}
return 0;
}
下面是一个WA2的代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
#define int unsigned long long
signed main()
{
int t;
cin>>t;
while(t--)
{
int n,k;
cin>>n>>k;
int ans=0;
int coun=0;
int x=(1+n)*n/2;
while(coun<k&&x>0)
{
int kk=x;
int nn=(-1+sqrt(1+8*kk))/2;
if(nn%2==0)
{
ans+=x/(nn+1)*(nn/2);
x=x/(nn+1)*(nn/2+1)/2;
}
else if(nn%2!=0)
{
ans+=x/nn*(nn/2+1);
x=x/nn*(nn/2)/2;
}
coun++;
}
int testans=0;
cout<<ans+x<<endl;
}
return 0;
}
这里nn是用 sqrt求的,精度有问题所以直接用nn/2的话会更好。
|