ABC190 D - Staircase Sequences(数学)
題意:
解法:
設 等 差 數 列 為 [ l , r ] 設等差數列為[l,r] 設等差數列為[l,r]
n ? ( a 1 + a n ) 2 \frac{n*(a_{1}+a_{n})}{2} 2n?(a1?+an?)?
( r ? l + 1 ) ( l + r ) 2 = n \frac{(r-l+1)(l+r)}{2}=n 2(r?l+1)(l+r)?=n
( r ? l + 1 ) ? ( l + r ) = 2 n (r-l+1)*(l+r)=2n (r?l+1)?(l+r)=2n
枚 舉 2 n 的 因 子 : 2 n = x ? y 枚舉2n的因子:2n=x*y 枚舉2n的因子:2n=x?y
那 么 可 以 列 出 方 程 : 那么可以列出方程: 那么可以列出方程:
l + r = x , r ? l + 1 = y l+r=x,r-l+1=y l+r=x,r?l+1=y
兩 式 相 加 得 2 r + 1 = x + y 兩式相加得2r+1=x+y 兩式相加得2r+1=x+y
判 斷 x + y 是 否 是 奇 數 即 可 . 判斷x+y是否是奇數即可. 判斷x+y是否是奇數即可.
同 時 , [ l , r ] 合 法 可 以 推 出 [ ? ( l ? 1 ) , r ] 也 合 法 同時,[l,r]合法可以推出[-(l-1),r]也合法 同時,[l,r]合法可以推出[?(l?1),r]也合法
所 以 每 找 到 一 組 合 法 的 解 , a n s + = 2 所以每找到一組合法的解,ans+=2 所以每找到一組合法的解,ans+=2
code:
#include<bits/stdc++.h> typedef long long ll; #define int long long using namespace std; void solve(){int n;cin>>n;n*=2;int ans=0;for(int i=1;i*i<=n;i++){if(n%i==0){int x=i,y=n/i;if((x+y)%2){ans+=2;}}}cout<<ans<<endl; } signed main(){ios::sync_with_stdio(0);int T=1;while(T--){solve();}return 0; }總結
以上是生活随笔為你收集整理的ABC190 D - Staircase Sequences(数学)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 汽车智能化的商业化路径、产业演进及投资机
- 下一篇: Yolov5训练自己的数据集+Tenso