【每日刷题】Day77

【每日刷题】Day77

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

[1. LCR 159. 库存管理 III - 力扣(LeetCode)](#1. LCR 159. 库存管理 III - 力扣(LeetCode))

[2. LCR 075. 数组的相对排序 - 力扣(LeetCode)](#2. LCR 075. 数组的相对排序 - 力扣(LeetCode))

[3. 1346. 检查整数及其两倍数是否存在 - 力扣(LeetCode)](#3. 1346. 检查整数及其两倍数是否存在 - 力扣(LeetCode))

1. LCR 159. 库存管理 III - 力扣(LeetCode)

//思路:TopK问题,堆排序。

void Swap(int* x,int* y)

{

int tmp = *x;

*x = *y;

*y = tmp;

}

//向下调整

void AdjustDown(int* arr,int parents,int size)

{

int child = parents*2+1;

while(child<size)

{

if(child+1<size&&arr[child+1]<arr[child])

child++;

if(arr[child]<arr[parents])

Swap(&arr[child],&arr[parents]);

else

break;

parents = child;

child = parents*2+1;

}

}

//堆排序

void HeapSort(int* arr,int size,int cnt)

{

for(int i = (size-2)/2;i>=0;i--)

{

AdjustDown(arr,i,size);

}

while(cnt)

{

Swap(&arr[0],&arr[size-1]);

size--;

cnt--;

AdjustDown(arr,0,size);

}

}

int* inventoryManagement(int* stock, int stockSize, int cnt, int* returnSize)

{

//堆排序将cnt个最小的数排到数组最后

HeapSort(stock,stockSize,cnt);

int* ans = (int*)malloc(sizeof(int)*stockSize);

int count = 0;

for(int i = stockSize-cnt;i<=stockSize-1;i++)

{

ans[count++] = stock[i];

}

*returnSize = count;

return ans;

}

2. LCR 075. 数组的相对排序 - 力扣(LeetCode)

//思路:哈希记数+遍历。遍历数组1,将数组1中每个元素出现的次数记录。随后遍历数组2,根据数组2的元素出现顺序将数组1中的元素放入新数组。

int* relativeSortArray(int* arr1, int arr1Size, int* arr2, int arr2Size, int* returnSize)

{

int* ans = (int*)malloc(sizeof(int)*(arr1Size));

int count = 0;

int hash[1001] = {0};

for(int i = 0;i<arr1Size;i++)

{

hash[arr1[i]]+=1;//记录数组1每个元素出现的次数

}

for(int i = 0;i<arr2Size;i++)

{

while(hash[arr2[i]])

{

ans[count++] = arr2[i];//遍历数组2,按照数组2的相对顺序放元素

hash[arr2[i]]--;

}

}

for(int i = 0;i<1001;i++)

{

while(hash[i])

{

ans[count++] = i;//将数组1中未在数组2中出现的元素放入

hash[i]--;

}

}

*returnSize = count;

return ans;

}

3. 1346. 检查整数及其两倍数是否存在 - 力扣(LeetCode)

//思路:排序+遍历判断。将数组排为升序,采用冒泡的方式挨个判断每个元素是否满足题意。注意:这里需要处理元素为负的情况。

void Swap(int* x,int* y)

{

int tmp = *x;

*x = *y;

*y = tmp;

}

//向下调整

void AdjustDown(int* arr,int parents,int size)

{

int child = parents*2+1;

while(child<size)

{

if(child+1<size&&arr[child+1]>arr[child])

child++;

if(arr[child]>arr[parents])

Swap(&arr[child],&arr[parents]);

else

break;

parents = child;

child = parents*2+1;

}

}

//堆排序

void HwapSort(int* arr,int size)

{

for(int i = (size-2)/2;i>=0;i--)

{

AdjustDown(arr,i,size);

}

while(size)

{

Swap(&arr[0],&arr[size-1]);

size--;

AdjustDown(arr,0,size);

}

}

bool checkIfExist(int* arr, int arrSize)

{

HwapSort(arr,arrSize);//排序

for(int i = 0;i<arrSize-1;i++)

{

for(int j = i+1;j<arrSize;j++)

{

if(arr[j]==2*arr[i]||(arr[j]<0&&arr[i]<0&&arr[i]==2*arr[j]))//遍历判断每个元素是否满足题意,需要处理元素为负的情况。

return true;

}

}

return false;

}

相关推荐
羊小猪~~几秒前
神经网络基础--什么是正向传播??什么是方向传播??
人工智能·pytorch·python·深度学习·神经网络·算法·机器学习
软工菜鸡26 分钟前
预训练语言模型BERT——PaddleNLP中的预训练模型
大数据·人工智能·深度学习·算法·语言模型·自然语言处理·bert
南宫生29 分钟前
贪心算法习题其三【力扣】【算法学习day.20】
java·数据结构·学习·算法·leetcode·贪心算法
希言JY38 分钟前
C字符串 | 字符串处理函数 | 使用 | 原理 | 实现
c语言·开发语言
午言若40 分钟前
C语言比较两个字符串是否相同
c语言
AI视觉网奇1 小时前
sklearn 安装使用笔记
人工智能·算法·sklearn
JingHongB1 小时前
代码随想录算法训练营Day55 | 图论理论基础、深度优先搜索理论基础、卡玛网 98.所有可达路径、797. 所有可能的路径、广度优先搜索理论基础
算法·深度优先·图论
weixin_432702261 小时前
代码随想录算法训练营第五十五天|图论理论基础
数据结构·python·算法·深度优先·图论
小冉在学习1 小时前
day52 图论章节刷题Part04(110.字符串接龙、105.有向图的完全可达性、106.岛屿的周长 )
算法·深度优先·图论
Repeat7151 小时前
图论基础--孤岛系列
算法·深度优先·广度优先·图论基础