秋招笔试|深信服提前批0611

题目略难-_-

选填

十来个选择填空,算法、八股、行测类似的逻辑题均有

算法一

N个节点,每个节点有一个时间和一个分数,问在规定时间内最多能拿到多少分
使用pair数据结构存储节点时间和分数,最开始将各节点按得分效率排序了,然后贪心算法只能过75,后考虑背包问题

#include <iostream>
#include <vector>
using namespace std;

int main() {
    // string T,S;
    // cin>>T;
    // cin>>S;
    // string total_ts;
    // cin>>total_ts;
    string T = "9,10,12";
    string S = "100,300,200";
    string total_ts = "20";
    vector<pair<int,int> > get_array;
    int now_number = 0;
    for(auto c:T){
        if(c>='0'&&c<='9')  now_number = now_number*10+c-'0';
        else {
            get_array.push_back(make_pair(now_number,0));
            now_number = 0;
        }
    }
    get_array.push_back(make_pair(now_number,0));
    now_number = 0;
    int index = 0;
    for(auto c:S){
        if(c>='0'&&c<='9')  now_number = now_number*10+c-'0';
        else {
            get_array[index++].second = now_number;
            now_number = 0;
        }
    }
    get_array[index++].second = now_number;
    int total_t = 0;
    for(auto c:total_ts){
        if(c>='0'&&c<='9')  total_t = total_t*10+c-'0';
    }

    int n = get_array.size(); 
    vector<vector<int>> dp(n + 1, vector<int>(total_t + 1, 0));

    for (int i = 1; i <= n; ++i) {
        for (int t = 1; t <= total_t; ++t) {
            if (get_array[i - 1].first <= t) {
                dp[i][t] = max(dp[i - 1][t], dp[i - 1][t - get_array[i - 1].first] + get_array[i - 1].second);
            } else {
                dp[i][t] = dp[i - 1][t];
            }
        }
    }
    int max_value=dp[n][total_t];
    cout << max_value << endl;

    system("pause");
    return 0;
}

算法二

玩家有k点体力,在一个图中,每移动一格消耗一点体力,可以向四个方向移动,求玩家从坐标00走到坐标mn的最短路径走法,若无法走到输出0
最短路径则仅考虑向右向下的路径即可,但按此思路仅过25,原因未知

#include <bits/stdc++.h>
using namespace std;

int main() {
    int k,m,n;
    cin>>k>>m>>n;
    if(m+n>k) return 0;

    vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0));
    dp[0][0] = 1;

    for (int i = 0; i <= m; ++i) {
        for (int j = 0; j <= n; ++j) {
            if (i > 0) {
                dp[i][j] += dp[i - 1][j];
            }
            if (j > 0) {
                dp[i][j] += dp[i][j - 1];
            }
        }
    }
    cout<<dp[m][n];
}
// 64 位输出请用 printf("%lld")

算法三

输入n个ip地址和编号,给出m个编号之间的联通关系,求两个ip地址之间需要多少次跳转才可以通信
难点在于数据的处理及保存为图的方式,初始化为01矩阵后求解两点之间的最短路径即可

#include <bits/stdc++.h>
using namespace std;

int judge_path(const vector<vector<int>>& array, int a, int b) {
    int n = array.size();
    vector<bool> visited(n, false);
    queue<pair<int, int>> q;

    q.push({a, 0});
    visited[a] = true;

    while (!q.empty()) {
        int current = q.front().first;
        int jumps = q.front().second;
        q.pop();

        if (current == b) {
            return jumps;
        }

        for (int i = 0; i < n; ++i) {
            if (array[current][i] == 1 && !visited[i]) {
                q.push({i, jumps + 1});
                visited[i] = true;
            }
        }
    }

    return -1;
}

int main() {
    int n,m;
    cin>>n>>m;
    unordered_map<string,int> my_map;
    for(int i = 0;i<n;i++){
        string temp_s;
        cin>>temp_s;
        int temp_index;
        cin>>temp_index;
        my_map[temp_s] = temp_index;
    }
    vector<vector<int> > array(n+1,vector<int>(n+1));
    for(int i =0;i<m;i++){
        int num1,num2;
        cin>>num1>>num2;
        array[num1][num2] = 1;
        array[num2][num1] = 1;
    }
    int judge_nums;
    cin>>judge_nums;
    for(int i =0;i<judge_nums;i++){
        string s1,s2;
        cin>>s1>>s2;
        // cout<<s1<<s2<<endl;
        cout<<judge_path(array,my_map[s1],my_map[s2])<<endl;
    }

}
// 64 位输出请用 printf("%lld")

算法四

给定一个初始状态随机的汉诺塔,初始状态满足八个大小不同的圆盘按从小到大的规则摆放在ab两柱上,问最少经过多少次可以将所有圆盘按从小到大的顺序摆放在c柱上
todo

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值