今日头条2018秋招笔试题(未完待续)

第一题:

#include <iostream>
#include <vector>
#include <string>
using namespace std;
void helper(const vector<vector<int>>& array, vector<vector<bool>>& check, int& cnt, int i, int j) {
    if (i < 0 || i >= array.size() || j < 0 || j >= array[0].size()) {
        return;
    }
    if (array[i][j] == 1 && !check[i][j]) {
        ++cnt;
        check[i][j] = true;
        helper(array, check, cnt, i-1, j-1);
        helper(array, check, cnt, i-1, j);
        helper(array, check, cnt, i-1, j+1);
        helper(array, check, cnt, i, j-1);
        helper(array, check, cnt, i, j+1);
        helper(array, check, cnt, i+1, j-1);
        helper(array, check, cnt, i+1, j);
        helper(array, check, cnt, i+1, j+1);
    } else {
        return;
    }
}
int main() {
    int M, N;
    char b;
    cin >> M >> b >> N;
    vector<vector<int>> array(M, vector<int>(N, 0));
    vector<vector<bool>> check(M, vector<bool>(N, false));
    int tmp;
    int i, j;
    for (i = 0; i < M; ++i) {
        for (j = 0; j < N - 1; ++j) {
            cin >> tmp;
            cin >> b;
            array[i][j] = tmp;
        }
        if (j == N - 1) {
            cin >> tmp;
            array[i][j] = tmp;
        }
    }
    int P = 0;
    int Q = 0;
    int cnt = 0;
    for (int i = 0; i < M; ++i) {
        for (int j = 0; j < N; ++j) {
            if (array[i][j] == 1 && !check[i][j]) {
                helper(array, check, cnt, i, j);
                Q = max(Q, cnt);
                cnt = 0;
                ++P;
            }
        }
    }
    cout << P << "," << Q << endl;
}

第一题主要考了递归调用,但这个带逗号的输入确实是个小陷阱,要换一种输入读取方法。

 

第二题:

#include <iostream>
#include <vector>
#include <string>
#include <sstream>
#include <algorithm>
using namespace std;
int main() {
    int T;
    cin >> T;
    vector<pair<int, int>> array;
    pair<int, int> tmp;
    string s;
    for (int i = 0; i < T+1; ++i) {
        getline(cin, s);
        istringstream is (s);
        int inter1, inter2;
        char ch;
        while (is >> inter1 >> ch >> inter2)
        {
            tmp.first = inter1;
            tmp.second = inter2;
            array.push_back(tmp);
            is >> ch;
        }
    }
    if (array.size() == 0) {
        return 0;
    }

    sort(array.begin(), array.end());

    vector<pair<int, int>> res;
    int a1 = array[0].first;
    int b1 = array[0].second;

    for (int i = 1; i < array.size(); ++i) {
        int a = array[i].first;
        int b = array[i].second;
        if (a <= b1) {
            b1 = max(b1, b);
        } else {
            res.push_back(pair<int, int>(a1, b1));
            a1 = a;
            b1 = b;
        }
    }
    res.push_back(pair<int ,int>(a1, b1));

    for (int i = 0; i < res.size() - 1; ++i) {
        cout << res[i].first << "," << res[i].second << ";";
    }
    cout << res[res.size() - 1].first << "," << res[res.size() - 1].second;
    return 0;
}

第二题在leetcode上有原题,只需要先对pair<int, int>做一个排序,之后的处理就很自然了;在输入输出格式上依然需要注意。

 

第三题:

不会.................

 

第四题:

思路:用dp的方式,将a/b 在空间i到j的区间的最大值/最小值求出来,再逐个空间进行比较;笔试没写完

 

第五题:

来不及看题...........

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我无法提供南方电网秋招笔试真的具体内容,因为我无法获取或提供特定公司的招聘信息。但是,我可以给你一些关于南方电网秋招笔试的一般性建议和常见型。 南方电网秋招笔试通常包括以下几个方面的内容: 1. 专业知识测试:涉及电力工程、电气工程、能源与动力工程等相关专业知识,包括电力系统、电力设备、电力工程管理等方面的知识。 2. 数学与逻辑推理:包括数学运算、概率统计、逻辑推理等方面的目。 3. 英语能力测试:主要考察英语阅读理解、词汇量和语法等方面的能力。 4. 综合素质测试:主要考察应聘者的综合素质,包括综合分析能力、创新思维、团队合作等方面。 在备考南方电网秋招笔试时,建议你注意以下几点: 1. 熟悉岗位要求:了解南方电网对应聘者的要求,明确自己所应聘的岗位所需的专业知识和技能。 2. 多做模拟:通过做一些模拟来熟悉型和考试时间,提高解速度和准确性。 3. 复习重点知识:重点复习与岗位相关的专业知识,包括电力系统、电力设备、电力工程管理等方面的知识。 4. 提高英语能力:加强英语阅读理解和词汇量的积累,可以通过阅读英文文章、做和听力练习等方式提高英语能力。 5. 注重综合素质:在备考过程中,注重培养自己的综合素质,包括综合分析能力、创新思维和团队合作等方面的能力。 希望以上建议对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值