关于找格子编号的题目。
#include<iostream>
using namespace std;
int get(int n)
{
int i;
int sum0=0;
int sum1=0;
float k;
for(i=1;i<7000;i++)
{
sum1=sum1+i;
if(n>sum1) continue;
else break;
}
sum0=sum1-i;
k=n-sum0;
if(0<k&&k<10) return k;
if(189>=k&&k>9)
{
float m=(k-9)/2;
int mm=(k-9)/2;
float b=m-mm;
int t;
if(b==0)
{
t=9+mm;
return t%10;
}
if(b==0.5)
{
t=10+mm;
return t/10;
}
}
if(2889>=k&&k>189)
{
float m=(k-189)/3;
int mm=(k-189)/3;
float b=m-mm;
int t=0;
if(0<b&&b<0.4)
{
t=100+mm;
return t/100;
}
if(0.4<b&&b<0.8)
{
t=100+mm;
return t/10%10;
}
else {
t=99+mm;
return t%10;
}
}
if(k>2899)
{
float m=(k-189)/4;
int mm=(k-189)/4;
float b=m-mm;
int t=0;
if(0<b&&b<0.3)
{
t=1000+mm;
return t/1000;
}
if(0.3<b&&b<0.6)
{
t=1000+mm;
return t/100%10;
}
if(b==0.75)
{
t=1000+mm;
return t/10%10;
}
else {
t=999+m;
return t%10;
}
}
}
int main()
{
int b;
cin>>b;
int x=get(b);
cout<<x<<endl;
system("pause");
return 0;
}