小米OJ 有多少个等差数列

题目链接 https://code.mi.com/problem/list/view?id=20

代码

 1 #include <bits/stdc++.h>
 2 
 3 using namespace std;
 4 
 5 int cnt = 0;
 6 
 7 void getNumVec(vector<int>& v, string s)
 8 {
 9     int temp = 0, flag = 1;
10     for (int i = 0;i < s.length(); ++i)
11     {
12         if (s[i] == ' ') 
13         {
14             v.push_back(temp * flag);
15             temp = 0;
16             flag = 1;
17         }
18         else if (s[i] == '-')
19         {
20             flag = -1;
21         }
22         else 
23         {
24             temp *= 10;
25             temp += s[i] - '0';
26         }
27     }
28     v.push_back(temp * flag);
29 }
30 
31 bool check(vector<int> v)
32 {
33     int sz = v.size();
34     if (sz < 2)
35     {
36         return false;
37     }
38 
39     if (sz == 2) 
40     {
41         return true;
42     }
43     
44     int d = v[1] - v[0];
45     for (int i = 2; i < sz; ++i)
46     {
47         if (v[i] - v[i - 1] != d)
48         {
49             return false;
50         }
51     }
52     return true;
53 }
54 
55 void dfs(vector<int>& v, vector<int>& temp, int start, int sz)
56 {
57     bool flag = false;
58     for (int i = start;i < sz; ++i)
59     {
60         temp.push_back(v[i]);
61         flag = check(temp);
62         if (flag || temp.size() < 2) //剪枝
63         {
64             if (flag)
65             {
66                 ++cnt;
67             }
68             dfs(v, temp, i + 1, sz);
69         }
70         temp.pop_back();
71     }
72 }
73 
74 int main()
75 {
76     string s;
77     getline(cin, s);
78 
79     vector<int> v, temp;
80     getNumVec(v, s);
81     int sz = v.size();
82     dfs(v, temp, 0, sz);
83 
84     cout << cnt << endl;
85     
86     return 0;
87 }

 

转载于:https://www.cnblogs.com/lj95/p/10331733.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值