【小米OJ-找到第N个数字】等差数列的使用

时间:2020-05-03 12:18:57   收藏:0   阅读:112

技术图片

 

 

#include<stdio.h>
#include<math.h>
int main(){
  long long n,m,i,x,s;
  int arr[16] = {2,1,2,3,4,5,6,7,8,9,8,7,6,5,4,3};
  scanf("%lld",&n);
  m = sqrt(2*n);///等差数列求和:sn = (a1+an)*n/2;
  for(i = m; i >= 0; i--)
     if(i*(i+1)<2*n)///等差数列
     {
         x = i;///找出上一项
         break;
     }
   s = n - (x+1)*x/2;///当前项的sn减去前一项sn就是当前项
  printf("%d\n",arr[s%16]);
  return 0;
}

  

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!