笔试——Day46

文章目录

第一题

题目

AOE还是单体?

思路

贪心

剩余怪物数量 >x时,使用AOE;否则使用单体

代码

cpp 复制代码
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 2e5 + 10;
int n, x;
int arr[N];
int main()
{
    cin >> n >> x;
    for (int i = 1; i <= n; i++)
        cin >> arr[i];
    sort(arr + 1, arr + 1 + n);
    long long ret = 0;
    int index = max(0, n - x); // 处理 x 过⼤的情况
    ret += arr[index] * x;
    for (int i = index + 1; i <= n; i++)
        ret += arr[i] - arr[index];
    cout << ret << endl;
    return 0;
}

第二题

题目

kotori和n皇后


思路

统计每一个皇后能攻击的位置,若已经有两个皇后可以相互攻击,则后续结果都为True

代码

cpp 复制代码
#include <iostream>
#include <unordered_set>

using namespace std;

unordered_set<long long> row; // 标记⾏ y
unordered_set<long long> col; // 标记列 x
unordered_set<long long> dig1; // 标记主对⻆线 y - x
unordered_set<long long> dig2; // 标记副对⻆线 y + x

int main()
{
    int n; cin >> n;
    int res = 1e5;
    for(int i = 1; i <= n; i++)
    {
        int x, y; cin >> x >> y;
        if(res != 1e5) continue;
        if(row.count(y) || col.count(x) || dig1.count(y - x) || dig2.count(y + x))
        {
            res = i;
        }
        row.insert(y); col.insert(x); 
        dig1.insert(y - x); dig2.insert(y + x);
    }
    int t; cin >> t;
    while(t--)
    {
        int i;
        cin >> i;
        if(i >= res) cout << "Yes" << endl;
        else cout << "No" << endl;
    }
    
    return 0;
}

第三题

题目

NC393 取金币

思路

动态规划

  • dp[i][j] 表示[i, j] 区间⼀共能获得多少⾦币

代码

cpp 复制代码
class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param coins int整型vector
     * @return int整型
     */
    int arr[110] = { 0 };
    int dp[110][110] = { 0 };
    int getCoins(vector<int>& coins) 
    {
        // write code here
        int n = coins.size();
        arr[0] = arr[n + 1] = 1;
        for (int i = 1; i <= n; i++) arr[i] = coins[i - 1];
        for (int i = n; i >= 1; i--) 
        {
            for (int j = i; j <= n; j++) 
            {
                for (int k = i; k <= j; k++) 
                {
                    dp[i][j] = max(dp[i][j], dp[i][k - 1] + dp[k + 1][j] + arr[i - 1] * arr[k] * arr[j + 1]);
                }
            }
        }
        return dp[1][n];
    }
};
相关推荐
森G2 小时前
29、QStringListModel 和 QListView---------Model/View模型视图
c++·qt
ALex_zry8 小时前
C++网络编程心跳机制与连接保活:长连接稳定性保障
开发语言·网络·c++
学嵌入式的小杨同学9 小时前
STM32 进阶封神之路(三十二):SPI 通信深度实战 —— 硬件 SPI 驱动 W25Q64 闪存(底层时序 + 寄存器配置 + 读写封装)
c++·stm32·单片机·嵌入式硬件·mcu·架构·硬件架构
米粒19 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
好大哥呀10 小时前
C++ Web 编程
开发语言·前端·c++
Fuxiao___10 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
ShineWinsu10 小时前
对于Linux:进程优先级、进程切换以及进程调度的解析
linux·面试·笔试·进程·进程切换·进程调度·进程优先级
Mr_Xuhhh10 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水10 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
南境十里·墨染春水11 小时前
C++ 笔记 友元(面向对象)
开发语言·c++·笔记