48.日常算法

news/2025/2/27 5:22:22

1.面试题 03.06. 动物收容所

题目来源

动物收容所。有家动物收容所只收容狗与猫,且严格遵守“先进先出”的原则。在收养该收容所的动物时,收养人只能收养所有动物中“最老”(由其进入收容所的时间长短而定)的动物,或者可以挑选猫或狗(同时必须收养此类动物中“最老”的)。换言之,收养人不能自由挑选想收养的对象。请创建适用于这个系统的数据结构,实现各种操作方法,比如enqueue、dequeueAny、dequeueDog和dequeueCat。允许使用Java内置的LinkedList数据结构。enqueue方法有一个animal参数,animal[0]代表动物编号,animal[1]代表动物种类,其中 0 代表猫,1 代表狗。dequeue*方法返回一个列表[动物编号, 动物种类],若没有可以收养的动物,则返回[-1,-1]。

示例 1:
输入:
[“AnimalShelf”, “enqueue”, “enqueue”, “dequeueCat”, “dequeueDog”, “dequeueAny”]
[[], [[0, 0]], [[1, 0]], [], [], []]
输出:
[null,null,null,[0,0],[-1,-1],[1,0]]

class AnimalShelf {
    queue<int> cats, dogs;
public:
    AnimalShelf() {
    }

    void enqueue(vector<int> animal) {
        int id = animal[0], type = animal[1];
        if (type) dogs.push(id);
        else cats.push(id);
    }
    
    vector<int> dequeueAny() {
        if (cats.empty()) return dequeueDog();
        else if (dogs.empty()) return dequeueCat();
        if (cats.front() < dogs.front()) return dequeueCat();
        return dequeueDog();
    }
    
    vector<int> dequeueDog() {
        if(dogs.empty()) return {-1, -1};
        int id = dogs.front();
        dogs.pop();
        return {id, 1};
    }
    
    vector<int> dequeueCat() {
        if(cats.empty()) return {-1, -1}; 
        int id = cats.front();
        cats.pop();
        return {id, 0};
    }
};

1.字母异位词分组

题目来源

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

示例 1:
输入: strs = [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”]
输出: [[“bat”],[“nat”,“tan”],[“ate”,“eat”,“tea”]]
示例 2:
输入: strs = [“”]
输出: [[“”]]

class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        unordered_map<string, vector<string>> hash;
        for (auto & s : strs){
            string temp = s;
            sort(temp.begin(), temp.end());
            hash[temp].push_back(s);
        }
        vector<vector<string>> ret;
        for (auto & [x, y] : hash){
            ret.push_back(y);
        }
        return ret;
    }
};

http://www.niftyadmin.cn/n/5869495.html

相关文章

解锁C# XML编程:从新手到实战高手的蜕变之路

一、引言&#xff1a;XML 在 C# 中的关键地位 在 C# 开发的广袤领域中&#xff0c;XML&#xff08;可扩展标记语言&#xff0c;eXtensible Markup Language&#xff09;宛如一颗璀璨的明星&#xff0c;占据着举足轻重的地位。它以其独特的结构化和自描述特性&#xff0c;成为了…

3.15 AI Agent 技术全景解析:从核心能力到企业级应用实践

AI Agent 技术全景解析:从核心能力到企业级应用实践 关键词:AI Agent 技术架构, 大模型智能体开发, 自主决策系统设计, 模块化 Agent 设计, 企业级 Agent 应用 1. AI Agent 的本质定义与核心能力 AI Agent 是具备环境感知、自主决策和持续进化能力的智能系统,其核心特征可…

编写MongoDB 开机启动脚本

1、创建脚本文件 touch /etc/init.d/mongodb.sh 2、添加启动脚本内容 先执行 vi /etc/init.d/mongodb.sh 将以下内容添加到mongodb.sh文件中&#xff1a; #!/bin/bash # # MongoDB startup script #### BEGIN INIT INFO # Provides: mongodb # Required-Start: …

操作系统知识点10

1.操作系统的任务之一是组织和管理计算机系统中的硬件及软件资源&#xff0c;为此在操作系统内部设计了各种数据结构&#xff0c;这些数据结构在操作系统运行这可以由系统动态更新。 2.用户可见寄存器包括数据寄存器&#xff0c;地址寄存器以及条件码寄存器。而程序寄存器&…

【杂谈】-2025年2月五大大型语言模型(LLMs)

2025年2月五大大型语言模型&#xff08;LLMs&#xff09; 文章目录 2025年2月五大大型语言模型&#xff08;LLMs&#xff09;1、GPT-4o2、Claude 3.5 Sonnet3、Gemini 2.0 Flash4、Grok 35、DeepSeek R16、应该使用哪个LLM&#xff1f; 大型语言模型&#xff08;LLMs&#xff0…

守护智慧医疗的“生命密钥”——安当TDE为电子病历筑起安全长城

引言&#xff1a;当医疗数字化遭遇“数据病毒” 2024年&#xff0c;某三甲医院因勒索病毒攻击导致3.7万份电子病历被加密&#xff0c;急救系统瘫痪12小时——这则新闻至今仍让医疗从业者心有余悸。在医疗行业全面数字化转型的今天&#xff0c;CT影像云存储、AI辅助诊断、远程手…

AI人工智能机器学习之神经网络

1、概要 本篇学习AI人工智能机器学习之神经网络&#xff0c;以MLPClassifier和MLPRegressor为例&#xff0c;从代码层面讲述最常用的神经网络模型MLP。 2、神经网络 - 简介 在 Scikit-learn 中&#xff0c;神经网络是通过 sklearn.neural_network 模块提供的。最常用的神经网…

用PySpark和PyTorch实现跨境支付Hive数据仓库的反洗钱数据分析

一、数据仓库表结构 假设我们有两个主要表&#xff1a; transactions &#xff08;交易表&#xff09;和 customers &#xff08;客户表&#xff09;。 transactions 表 CREATE TABLE transactions (transaction_id STRING,customer_id STRING,counterparty_id STRING,trans…