滴滴测开笔试第二道编程AC代码

#include<iostream>
#include<vector>
using namespace std;
int main()
{
    int n;
    while(cin >> n){
        vector<int> data(n);
        int sum = 0;
        for(int i = 0; i < n; i++){
            cin >> data[i];
            sum += data[i];
        }
        if(n < 6)cout << sum << endl;//如果是小于6,直接输出
        else{
            for(int j = 3; j <= n; j++){//对3边形以上枚举
                if(n%j == 0){//求余,子边形
                    int tsum = 0, step = n/j;//tsum是每组的和,step是步长
                    for(int i = 0; i < n/j; i++){//枚举开始的起点
                        tsum = 0;
                        for(int k = i; k < n; k += step)
                            tsum += data[k];//算每个子边形的和
                        sum = max(tsum, sum);//取最大
                    }
                }
            }
        }
        cout << sum << endl;
    }    
    return 0;
} 

#滴滴##笔试题目##秋招##题解##测试开发工程师#
全部评论
大佬第一道ac了吗,想求一下代码
点赞 回复 分享
发布于 2019-08-27 21:11
大佬能给讲一下对题目的理解吗?我当时也是觉得n边形可以转换成n能整除的数k边形,但是后面画图,觉得8边形可以转换成6边形,然后就没往这方面继续解题了。觉得我可能还是对题目理解不够透彻。
点赞 回复 分享
发布于 2019-08-27 21:27
点赞终于看到对的了
点赞 回复 分享
发布于 2019-08-28 15:30

相关推荐

点赞 评论 收藏
分享
4 6 评论
分享
牛客网
牛客企业服务