AtcoderABC245场

A - Good morningA - Good morning

题目大意

给定Takahashi和Aoki的起床时间,判断谁先起床。

思路分析

题目要求比较Takahashi和Aoki的起床时间。首先,将起床时间转换为以分钟为单位。然后,通过比较两者的起床时间来确定谁先起床。

时间复杂度

O(1)

知识点标签

基本的数学运算

可AC代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main(void) {
	int a, b, c, d;
	cin >> a >> b >> c >> d;
	if (a < c)cout << "Takahashi" << endl;
	else if (a > c)cout << "Aoki" << endl;
	else {
		if (b <= d)cout << "Takahashi" << endl;
		else cout << "Aoki" << endl;
	}
	return 0;
}

B - MexB - Mex

题目大意

给定一个整数序列,找到最小的非负整数,该整数不在序列中。

思路分析

为了找到最小的非负整数,可以遍历整数序列,并使用一个集合(或数组)来记录序列中出现的所有整数。然后,从0开始逐个判断整数是否在集合中,直到找到第一个不在集合中的非负整数为止。

时间复杂度

O(N)

知识点标签

数组(或集合)

可AC代码

cpp 复制代码
#include<iostream>
#include<unordered_set>
using namespace std;
int main()
{
int n;
cin>>n;
unordered_set<int> num;
for(int i=0;i<n;i++)
{
int nu;
cin>>nu;
num.insert(nu);
}
int  sm=0;
while(num.find(sm)!=num.end())
{sm++;
}
cout<<sm<<endl;
return 0;
}

C - Choose ElementsC - Choose Elements

题目大意

给定两个长度为N的整数序列A和B,判断是否存在一个长度为N的序列X满足以下条件:

  • 对于每个i(1 <= i <= N),有Xi = Ai或Xi = Bi。
    对于每个i(1 <= i <= N-1),有|Xi - Xi+1| <= K。

思路分析

可以使用动态规划来解决这个问题。定义dp[i]表示考虑到(X1, X2, ..., Xi)的情况下,是否可以让Xi = Ai,定义ep[i]表示考虑到(X1, X2, ..., Xi)的情况下,是否可以让Xi = Bi。根据题目条件,可以得出以下转移方程:

  • 如果dp[i-1]=True且|Ai-1 - Ai| <= K,则dp[i]=True。
  • 如果ep[i-1]=True且|Bi-1- Ai| <= K,则dp[i]=True。
    否则,dp[i]=False。 同样地,可以计算ep[i]的值。
    接下来,初始化dp[1]=True和ep[1]=True,并进行逐个计算dp[i]和ep[i]的值。最终,如果dp[N]=True或ep[N]=True,则说明存在满足条件的序列X,否则不存在。

时间复杂度

O(N)

知识点标签

动态规划

可AC代码

cpp 复制代码
#include <iostream>
#include <vector>
#include <unordered_set>
#include <cmath>
using namespace std;

int main() {
    int N, K;
    cin >> N >> K;
    vector<int> A(N), B(N);
    for (int i = 0; i < N; ++i) {
        cin >> A[i];
    }
    for (int i = 0; i < N; ++i) {
        cin >> B[i];
    }

    unordered_set<int> before;
    before.insert(A[0]);
    before.insert(B[0]);

    for (int i = 1; i < N; ++i) {
        unordered_set<int> tmp;
        for (int b : before) {
            if (abs(b - A[i]) <= K) {
                tmp.insert(A[i]);
            }
            if (abs(b - B[i]) <= K) {
                tmp.insert(B[i]);
            }
        }

        if (tmp.empty()) {
            cout << "No" << endl;
            return 0;
        }

        before = tmp;
    }

    cout << "Yes" << endl;

    return 0;
}
相关推荐
Star在努力21 分钟前
15-C语言:第15~16天笔记
c语言·笔记·算法
CoovallyAIHub26 分钟前
工业质检新突破!YOLO-pdd多尺度PCB缺陷检测算法实现99%高精度
深度学习·算法·计算机视觉
gb421528726 分钟前
负载均衡算法中的加权随机算法
windows·算法·负载均衡
xdlka1 小时前
C++初学者4——标准数据类型
开发语言·c++·算法
go54631584651 小时前
大规模矩阵构建与高级算法应用
线性代数·算法·矩阵
向左转, 向右走ˉ2 小时前
为什么分类任务偏爱交叉熵?MSE 为何折戟?
人工智能·深度学习·算法·机器学习·分类·数据挖掘
霜绛3 小时前
机器学习笔记(四)——聚类算法KNN、Kmeans、Dbscan
笔记·算法·机器学习·kmeans·聚类
晨非辰4 小时前
#C语言——学习攻略:深挖指针路线(三)--数组与指针的结合、冒泡排序
c语言·开发语言·数据结构·学习·算法·排序算法·visual studio
zzywxc7874 小时前
编程算法在金融、医疗、教育、制造业等领域的落地案例
人工智能·算法·金融·自动化·copilot·ai编程
zzywxc7874 小时前
编程算法在金融、医疗、教育、制造业的落地应用。
人工智能·深度学习·算法·机器学习·金融·架构·开源