题解 | #拦截导弹#

拦截导弹

https://www.nowcoder.com/practice/dad3aa23d74b4aaea0749042bba2358a

#include<stdio.h>
#define true 1
#define false 0
static int max = 0, j = 0, B[30];
int check() {
    int i;
    for (i = 0; i < j - 1; i++) {
        if (B[i] < B[i + 1])return false;
    }
    return true;
}
void backtracking(int* A, int n, int startIndex) {
    int i;
    if (startIndex >= n || check() == false)return;
    if (j > max)max = j;
    for (i = startIndex; i < n; i++) {
        B[j++] = A[i];
        if (check() == true && j > max)max = j;
        backtracking(A, n, i + 1);
        j--;
    }
}
int main() {
    int i, n;
    for (i = 0; i < 30; i++)B[i] = 0;
    scanf("%d", &n);
    int A[n];
    for (i = 0; i < n; i++)scanf("%d", &A[i]);
    backtracking(A, n, 0);
    printf("%d", max);
    return 0;
}

全部评论

相关推荐

淬月星辉:专利是什么?至少描述一下吧,然后把什么计算机二级、普通话这种拉低格调的证书删掉,不然hr以为你没东西写
点赞 评论 收藏
分享
10-31 13:04
南华大学 Java
嵌入式的小白:很多面试,面试前不会去打扰cto的,但一般cto不会在这些小事上刷人,只能说这个cto比较操心,啥重要不重要,紧急不紧急的,估计都会过问,平淡看待吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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