8.25 bilibili 算法笔试

不太清楚哪些边界条件没有判断,比如它题目中给出 fee > 0 ,我还需要在程序里判断一下嘛?
(好像测试的时候,判断 fee <= 0,过的案例更少了,不知道是什么问题
求大佬们指教一下!!感谢感谢!!!
1. 股票 0.83
#include<bits/stdc++.h>
using namespace std;

int main(){
    string str;
    cin >> str;
    if (str.size() <= 2) return 0;
    vector<int> price;
    for (int i = 1; i < str.size() - 1; i += 2){
        if (str[i] <= '9' && str[i] >= '0'){
            int tmp = str[i] - '0';
            price.push_back(tmp);
        }
    }
    int fee;
    cin >> fee;
    int n = price.size();
    vector<vector<int>> dp(n, vector<int>(2, 0));
    dp[0][0] -= price[0];
    for (int i = 1; i < n; ++i){
        dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] - price[i]);
        dp[i][1] = max(dp[i - 1][1], dp[i - 1][0] + price[i] - fee);
    }
    cout << max(dp[n - 1][0], dp[n - 1][1]);
    return 0;
}

2.举手 1.00
#include<bits/stdc++.h>
using namespace std;


int main(){
    int A[12];
    for (int i = 1; i <= 10; i++) cin >> A[i];
    A[0] = A[10];
    A[11] = A[1];
    int temp[12];
    int m;
    cin >> m;
    while (m--){
        for (int i = 1; i <= 10; i++){
            temp[i] = A[i - 1] ^ A[i + 1];
        }
        for (int j = 1; j <= 10; j++){
            A[j] = temp[j];
        }
        A[0] = temp[10];
        A[11] = temp[1];
    }
    for (int i = 1; i <= 10; i++) cout << A[i] << ' ';
    return 0;
}

3. score  0.5
#include<bits/stdc++.h>
using namespace std;
#define ll long long

int A[300010];
ll sumA[300010];	// 前 i 个数的和
int n, k;
ll res = LLONG_MIN;

void backtracking(int K, int Sum, int startIndex){
    if (K == k){
        if (startIndex < n){
            Sum += K * (sumA[n] - sumA[startIndex] + A[startIndex]);
            res = res > Sum ? res : Sum;
        }
        return;
    }
    for (int i = startIndex; i <= n - 1 -(k - K); i++){
        if (i == 0) continue;
        Sum += K * (sumA[i] - sumA[startIndex] + A[startIndex]);
        K++;
        backtracking(K, Sum, i + 1);
        K--;
        Sum -= K * (sumA[i] - sumA[startIndex] + A[startIndex]);
    }
}

int main(){
    cin >> n >> k;
    for (int i = 1; i <= n; ++i) cin >> A[i];
    for (int i = 1; i <= n; ++i) sumA[i] += sumA[i - 1] + A[i];	// sumA[0] = 0;
    backtracking(1, 0, 0);
    cout << res;
    return 0;
}




#哔哩哔哩笔试##哔哩哔哩##笔经#
全部评论

相关推荐

关于我大学本科四年,想了很多,但还是不知道该怎么动笔&nbsp;“大学四年,是我从懵懂少年走向职场青年的转折期。这一路跌跌撞撞,有迷茫,有遗憾,也有成长和决心。”&nbsp;大一刚进来时仍然有高中那股学习劲,经常一个人去图书馆学高等数学,但后面劲头一过便开始在宿舍开启躺平生活(现在想想那段时间真的很爽,无忧无虑)。由于大一担任班干部,所以经常要跟其他班的班干部交流,在此期间认识了隔壁班的一位女生,短发而很可爱,因为很多团建还有比赛都是我们两班一起参加的,而且我和她都是负责人,所以交集很多,后面慢慢地彼此对产生了好感,所以在大一刚开学的2个月后,我们在一起了,彼此之前都是初恋。但当时我真的是太太太直男了,对感情的想...
真烦好烦真烦:骗哥们可以,别把你自己也骗到了就行。哥们被你骗了真无所谓的,打个哈哈就过了。但希望你打完这段话后擦一下眼角,别让眼泪掉在手机屏幕上了就行。你说的这些话,哥们信一下也是没什么的。还能让你有个心里安慰,但这种话说出来骗骗兄弟就差不多得了,哥们信你一下也不会少块肉,但是你别搞得自己也当真了就行。哥们被你骗一下是真无所谓的,兄弟笑笑也就过去了。真不是哥们想要破你防,你擦擦眼泪好好想想,除了兄弟谁还会信你这些话?
点赞 评论 收藏
分享
评论
2
5
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务