题解 | #查询满足区间的记录#

查询满足区间的记录

https://www.nowcoder.com/practice/3eb4f4f8128a4372880ea73e2bbc0d7e

解题思路

这是一道时间区间查询问题,主要思路如下:

  1. 问题分析:

    • 输入包含多条订单记录
    • 每条记录包含订单号、入店时间、离店时间
    • 需要查找指定时间点在入店和离店时间之间的订单
    • 结果需要按订单号升序排序
  2. 解决方案:

    • 使用结构体存储订单信息
    • 遍历所有订单判断时间是否符合要求
    • 将符合条件的订单号存入数组
    • 对结果进行排序后输出
  3. 实现细节:

    • 使用结构体封装订单信息
    • 使用数组存储符合条件的订单号
    • 使用排序函数对结果排序

代码

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

const int MAXN = 50005;

struct Order {
    int id;
    int start;
    int leave;
};

int main() {
    int n;
    cin >> n;
    int queryTime;
    cin >> queryTime;
    
    Order orders[MAXN];
    int result[MAXN];
    int count = 0;
    
    // 读取订单信息
    for(int i = 0; i < n; i++) {
        cin >> orders[i].id >> orders[i].start >> orders[i].leave;
        // 判断是否在时间范围内
        if(queryTime >= orders[i].start && queryTime <= orders[i].leave) {
            result[count++] = orders[i].id;
        }
    }
    
    // 对结果排序
    sort(result, result + count);
    
    // 输出结果
    if(count == 0) {
        cout << "null" << endl;
    } else {
        for(int i = 0; i < count; i++) {
            cout << result[i] << endl;
        }
    }
    
    return 0;
}
import java.util.*;

public class Main {
    static class Order {
        int id;
        int start;
        int leave;
        
        Order(int id, int start, int leave) {
            this.id = id;
            this.start = start;
            this.leave = leave;
        }
    }
    
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int queryTime = sc.nextInt();
        
        Order[] orders = new Order[n];
        ArrayList<Integer> result = new ArrayList<>();
        
        // 读取订单信息
        for(int i = 0; i < n; i++) {
            int id = sc.nextInt();
            int start = sc.nextInt();
            int leave = sc.nextInt();
            orders[i] = new Order(id, start, leave);
            
            // 判断是否在时间范围内
            if(queryTime >= start && queryTime <= leave) {
                result.add(id);
            }
        }
        
        // 对结果排序
        Collections.sort(result);
        
        // 输出结果
        if(result.isEmpty()) {
            System.out.println("null");
        } else {
            for(int id : result) {
                System.out.println(id);
            }
        }
        
        sc.close();
    }
}
class Order:
    def __init__(self, id, start, leave):
        self.id = id
        self.start = start
        self.leave = leave

def main():
    n = int(input())
    query_time = int(input())
    
    result = []
    
    # 读取订单信息
    for _ in range(n):
        id, start, leave = map(int, input().split())
        # 判断是否在时间范围内
        if query_time >= start and query_time <= leave:
            result.append(id)
    
    # 对结果排序
    result.sort()
    
    # 输出结果
    if not result:
        print("null")
    else:
        for id in result:
            print(id)

if __name__ == "__main__":
    main()

算法及复杂度

  • 算法:排序
  • 时间复杂度: - 主要是排序的时间复杂度
  • 空间复杂度: - 需要存储订单信息和结果
全部评论

相关推荐

2025-12-14 11:43
黑龙江大学 Java
用微笑面对困难:确实比较烂,可以这么修改:加上大学的qs排名,然后大学简介要写一些,然后硕士大学加大加粗,科研经历第一句话都写上在复旦大学时,主要负责xxxx,简历左上角把学校logo写上,建议用复旦大学的简历模板
点赞 评论 收藏
分享
2025-12-27 18:11
已编辑
门头沟学院 前端工程师
28双非鼠鼠第一份实习,感谢金山,感谢面试官张先生的赏识,也感谢自己很开心很开心(有没有待过的前辈,求摸鱼技巧bushi)timeline12.15&nbsp;投递12.16&nbsp;约面12.18&nbsp;一面&nbsp;半个小时后约二面12.19&nbsp;二面,口头oc12.24&nbsp;发offer一面1.&nbsp;开发页面中使用的布局方式2.&nbsp;flex:&nbsp;1&nbsp;是什么的缩写3.&nbsp;水平居中的方法4.&nbsp;tailwindcss&nbsp;的优势5.&nbsp;js&nbsp;的闭包6.&nbsp;打印结果的题,解释为什么(var&nbsp;定义&nbsp;i&nbsp;,setTimeout&nbsp;执行打印),使用&nbsp;let&nbsp;的打印结果7.&nbsp;箭头函数和普通函数的区别8.&nbsp;promise&nbsp;构造函数是同步还是异步9.&nbsp;内存泄漏的情况10.&nbsp;interface&nbsp;和&nbsp;type&nbsp;的区别11.&nbsp;react&nbsp;的&nbsp;key&nbsp;作用12.&nbsp;常用的钩子函数13.&nbsp;怎么避免不必要的渲染14.&nbsp;useeffect&nbsp;的使用场景15.&nbsp;react&nbsp;和&nbsp;vue&nbsp;怎么选择16.&nbsp;vue&nbsp;的&nbsp;data&nbsp;为什么用函数17.&nbsp;tcp&nbsp;为什么需要三次握手和四次挥手18.&nbsp;vite&nbsp;为什么比较快19.&nbsp;解释防抖节流和手写防抖函数,还有实现思路20.&nbsp;深浅拷贝的区别和手写深拷贝,讲实现思路反问了业务,反馈时间和学习建议二面基本上是围绕项目展开,根据项目的每一项,来给场景题问你会怎么做,跟基础相关的东西如下:1.&nbsp;虚拟列表的实现和原理2.&nbsp;zustand&nbsp;和&nbsp;context&nbsp;的区别3.&nbsp;vitest&nbsp;相关,写测试的话应该怎么做些什么?4.&nbsp;monorepo的细节问题5.&nbsp;做项目的动机6.&nbsp;事件委托和时间冒泡的区别有个点顺着问了我五个问题实在是答不下去了就是说感觉金山云这边面试虽然一面全是八股,但是二面还是要好好准备项目,做到能被深挖那么两三个问题的程度,鼠鼠也是运气很好,问的都是准备过的嘻嘻面试完之后还很期待这个面试官会不会是我mt或者ld,会很认真的听我说话,然后告诉我哪里有小问题,不知道是不是鼠鼠的错觉,感觉他看后辈的眼神都是带有欣赏的意味真的很复合我对mt/ld的幻想(bushi),但是后来发现他ip是北京的qwq有点点小失落,不过没关系,看隔壁某书感觉金山的节奏还挺慢的期待入职ing愿一切顺利,好运常伴吾身这里再吐槽一下流程,怎么!!这么!!慢!!急死我了急死我了!!鬼知道我从周一到接到offer这段时间有多煎熬,哎呀但是但是好在一切如愿
发面经攒人品
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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