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

Posted 一路一歌

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小米OJ-找到第N个数字等差数列的使用相关的知识,希望对你有一定的参考价值。

 

 

#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;
}

  

以上是关于小米OJ-找到第N个数字等差数列的使用的主要内容,如果未能解决你的问题,请参考以下文章

小米OJ-找多少个等差数列动态规划

九度oj 题目1496:数列区间

小米oj 找出旋转有序数列的中间值

[小米OJ] 7. 第一个缺失正数

[小米OJ] 9. 移除 K 位得到最小值

小米oj 找出单独出现的数字