【每日刷题】Day39

【每日刷题】Day39

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. 622. 设计循环队列 - 力扣(LeetCode)

2. 387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

3. 2073. 买票需要的时间 - 力扣(LeetCode)

1. 622. 设计循环队列 - 力扣(LeetCode)

//思路:顺序表。

typedef int QDataType;


 

typedef struct//循环队列结构体,包含有一数组,指向头和尾的变量head和tail,数组有效长度k

{

    QDataType* arr;

    int head;

    int tail;

    int k;

} MyCircularQueue;


 

MyCircularQueue* myCircularQueueCreate(int k)//创建循环队列并初始化

{

    MyCircularQueue* obj = (MyCircularQueue*)malloc(sizeof(MyCircularQueue));

    obj->arr = malloc(sizeof(QDataType)*(k+1));

    obj->head = obj->tail = 0;

    obj->k = k;

    return obj;

}

bool myCircularQueueEnQueue(MyCircularQueue* obj, int value)//入列

{

    if((obj->tail+1)%(obj->k+1)==obj->head)//循环队列判满

    {

        return false;

    }

    obj->arr[obj->tail++] = value;//入列

    obj->tail%=(obj->k+1);//设计为循环,当越界时可以回到0

    return true;

}

bool myCircularQueueDeQueue(MyCircularQueue* obj)//出列

{

    if(obj->head==obj->tail)//判空

    {

        return false;

    }

    obj->head++;

    obj->head%=(obj->k+1);//同样是设计为循环,越界时回到0

    return true;

}

int myCircularQueueFront(MyCircularQueue* obj)//获取队头元素

{

    if(obj->head==obj->tail)//判空

    {

        return -1;

    }

    return (obj->arr[obj->head]);

}

int myCircularQueueRear(MyCircularQueue* obj)//获取队尾元素

{

    if(obj->head==obj->tail)//判空

    {

        return -1;

    }

    return obj->arr[(obj->tail+obj->k)%(obj->k+1)];//这里比较难懂,可以原式是((obj->tail-1+k+1)%(k+1)),这里目的是为了处理tail为0时-1越界的情况

}

bool myCircularQueueIsEmpty(MyCircularQueue* obj)//判空

{

    return (obj->tail==obj->head);

}

bool myCircularQueueIsFull(MyCircularQueue* obj)//判满

{

    return (obj->tail+1)%(obj->k+1)==obj->head;

}

void myCircularQueueFree(MyCircularQueue* obj)//释放

{

    free(obj->arr);

    free(obj);

}

2. 387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

//思路:二次遍历。第一次遍历用哈希表存储字符出现的次数,第二次遍历根据哈希表判断该字符出现的次数,来判断是否为答案

int firstUniqChar(char* s)

{

    int hash[26] = {0};

    int i = 0;

    for(i = 0;i<strlen(s);i++)//存储每个字符出现的个数

    {

        hash[s[i]-'a']+=1;

    }

    for(i = 0;i<strlen(s);i++)

    {

        if(hash[s[i]-'a']==1)//找到只出现一次的字符返回下标

        {

            return i;

        }

    }

    return -1;

}

3. 2073. 买票需要的时间 - 力扣(LeetCode)

//思路:循环遍历数组。

int timeRequiredToBuy(int* tickets, int ticketsSize, int k)

{

    int ans = 0;

    int i = 0;

    while(tickets[k]!=0)//第k个人没买完票循环继续

    {

        if(tickets[i]!=0)//每一个人买票,时间+1

        {

            ans++;

            tickets[i]--;

        }

        i++;

        i%=ticketsSize;//当遇到数组末尾时,回到头,模拟排队

    }

    return ans;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/11553.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

百度云防护502 Bad Gateway原因总结和处理方法

最近&#xff0c;随着原百度云加速用户新接入百度云防护后&#xff0c;很多站长反馈网站打不开&#xff0c;出现了502 Bad Gateway的情况。 为此&#xff0c;百度云这里给大家总结下&#xff0c;出现502的大概几个原因&#xff1a; 1.服务器防火墙拦截了百度云防护的IP节点请求…

vivado Kintex UltraScale+ 配置存储器器件

Kintex UltraScale 配置存储器器件 下表所示闪存器件支持通过 Vivado 软件对 Kintex UltraScale 器件执行擦除、空白检查、编程和验证等配置操作。 本附录中的表格所列赛灵思系列非易失性存储器将不断保持更新 &#xff0c; 并支持通过 Vivado 软件对其中所列非易失性存…

【VUE.js】前端框架——未完成

基于脚手架创建前端工程 环境 当安装node.js时&#xff0c;它本身就携带有npm命令。&#xff08;-v 查版本号&#xff09;安装VUE CLI npm i vue/cli -g&#xff08;全局&#xff09; 创建 vue create 【project name】 镜像源解决方案 输入创建命令后&#xff0c;提示检查更…

【JAVA】JAVA的垃圾回收机制详解

对于Java的垃圾回收机制&#xff0c;它是Java虚拟机&#xff08;JVM&#xff09;提供的一种自动内存管理机制&#xff0c;主要负责回收不再使用的对象以释放内存空间。垃圾回收机制主要包括以下几个方面的内容&#xff1a; 垃圾对象的识别&#xff1a;Java虚拟机通过一些算法&…

Taro@3.x+Vue@3.x+TS开发微信小程序,网络请求封装

参考文档 Taro.request(option) 在 src/http 下创建 request.ts, 写入如下配置&#xff1a; import Taro from tarojs/taro import { encryptData } from ./encrypt // 请求数据加密&#xff0c;可选console.log(NODE_ENV, process.env.NODE_ENV) console.log(TARO_APP_PROX…

C++学习笔记3

A. 求出那个数 题目描述 喵喵是一个爱睡懒觉的姑娘&#xff0c;所以每天早上喵喵的妈妈都花费很大的力气才能把喵喵叫起来去上学。 在放学的路上&#xff0c;喵喵看到有一家店在打折卖闹钟&#xff0c;她就准备买个闹钟回家叫自己早晨起床&#xff0c;以便不让妈妈这么的辛苦…

Leetcode 3143. Maximum Points Inside the Square

Leetcode 3143. Maximum Points Inside the Square 1. 解题思路2. 代码实现 题目链接&#xff1a;3143. Maximum Points Inside the Square 1. 解题思路 这一题由于都是从中心开始的正方形&#xff0c;因此&#xff0c;我们只要找到所有tag下的点距离中心的位置最小的点&…

Caddy2使用阿里云DNS申请https证书,利用阿里云DNS境内外不同解析给Gone文档做一个同域名的国内镜像站点

我从头到尾实现了一个Golang的依赖注入框架&#xff0c;并且集成了gin、xorm、redis、cron、消息中间件等功能&#xff1b;自己觉得还挺好用的&#xff0c;并且打算长期维护&#xff01; github地址&#xff1a;https://github.com/gone-io/gone 文档原地址&#xff1a;https:/…

2024CCPC郑州站超详细题解(含题面)ABFHJLM(河南全国邀请赛)

文章目录 前言A Once In My LifeB 扫雷 1F 优秀字符串H 随机栈J 排列与合数L Toxel 与 PCPC IIM 有效算法 前言 这是大一博主第一次参加xcpc比赛&#xff0c;虽然只取得了铜牌&#xff0c;但是收获满满&#xff0c;在了解了和别人的差距后会更加激励自己去学习&#xff0c;下面…

MySQL变量的定义与应用

DQL #MySQL变量的定义与应用 set userName小可爱; select userName; # 定义数值类型整数小数 set x5,y7; select xy, x-y, x*y,x/y; #1、字符串查询 set cityNameHaag; SELECT * FROM city where Name cityName; #2、数值类型 set popvalue105819; select * from city where P…

Python Pandas 数据分析快速入门

Python Pandas 数据分析快速入门 Pandas 是一个开源的 Python 数据分析库&#xff0c;它提供了高效的 DataFrame 结构来处理大型数据集&#xff0c;常用于数据清洗和分析工作。在本教程中&#xff0c;我们将介绍如何使用 Pandas 进行基本的数据分析操作&#xff0c;以及如何处…

34岁2个娃的女程序真的要回归家庭了吗?

我34岁已婚已育&#xff0c;家里两个娃。在去年年末的裁员大潮中被裁了。目前已经找工作2个月&#xff0c;本来被裁我还挺开心的&#xff0c;我老二还在哺乳期&#xff0c;妥妥的4n的工资。赶紧裁了要我好好玩玩吧。抱着这种兴高采烈的心态那这赔偿跑路了。刚好被裁之后紧接着就…

Python从0到POC编写--函数

数学函数&#xff1a; 1. len len() 函数返回对象&#xff08;字符、列表、元组等&#xff09;长度或项目个数&#xff0c; 例如&#xff1a; str "python" len(str)2. range range() 函数返回的是一个可迭代对象&#xff08;类型是对象&#xff09;&#xff0c;…

并行执行的4种类别——《OceanBase 并行执行》系列 4

OceanBase 支持多种类型语句的并行执行。在本篇博客中&#xff0c;我们将根据并行执行的不同类别&#xff0c;分别详细阐述&#xff1a;并行查询、并行数据操作语言&#xff08;DML&#xff09;、并行数据定义语言&#xff08;DDL&#xff09;以及并行 LOAD DATA 。 《并行执行…

对Whisper模型的静音攻击

针对Whisper模型的静音攻击方法主要针对基于Transformer的自动语音识别系统&#xff0c;特别是Whisper系列模型。其有效性主要基于Whisper模型使用了一些“特殊标记”来指导语言生成过程&#xff0c;如标记表示转录结束。我们可以通过在目标语音信号前添加一个通用短音频段&…

vue项目通过点击文字上传html文件,查看html文件

上传html文件 解决思路&#xff1a;新建一个上传组件&#xff0c;将它挪到页面之外。当点击文字时&#xff0c;手动触发上传组件&#xff0c;打开上传文件框。 <template><BasicTable register"registerTable"><template #bodyCell"{ column, …

UIButton案例之添加动画

需求 基于上一节代码进行精简&#xff0c;降低了冗余性。添加动画&#xff0c;使得坐标变化自然&#xff0c;同时使用了bounds属性和center属性&#xff0c;使得UIView变化以中心点为基准。 此外&#xff0c;使用两种方式添加动画&#xff1a;1.原始方式。 2.block方式。 代码…

vm虚拟机扩容centos磁盘内存

1.查看虚拟机扩展前磁盘内存 df -h 2.关机情况下扩展磁盘内存 3.对扩容的磁盘分区 fdisk /dev/sda 输入n新增分区&#xff0c;回车&#xff0c;选择p&#xff0c;回车 为分区设置分区格式&#xff0c;在Fdisk命令处输入&#xff1a;t 分区号用默认 3&#xff08;或回车&…

OSS证书自动续签,一分钟轻松搞定,解决阿里云SSL免费证书每3个月失效问题

文章目录 一、&#x1f525;httpsok-v1.11.0支持OSS证书自动部署介绍支持特点 二、废话不多说上教程&#xff1a;1、场景2、实战Stage 1&#xff1a;ssh登录阿里云 ECSStage 2&#xff1a;进入nginx &#xff08;docker&#xff09;容器Stage 3&#xff1a;执行如下指令Stage 3…

测试环境搭建整套大数据系统(十六:超级大文件处理遇到的问题)

一&#xff1a;yarn出现损坏的nodemanger 报错现象 日志&#xff1a;1/1 local-dirs usable space is below configured utilization percentage/no more usable space [ /opt/hadoop-3.2.4/data/nm-local-dir : used space above threshold of 90.0% ] ; 1/1 log-dirs usabl…