LeetCode 230.二叉搜索树中第K小的元素

各位看官们,大家好啊,今天这个题我用的方法时间复杂度比较高,但也是便于便于理解的一种方法,大家如果觉得的好的话,就给个免费的赞吧,谢谢大家了^ _ ^

题目要求如图所示:

题目步骤:
1.我们可以一维数组来接收各个二叉树结点的值:

c 复制代码
	//number是数组的大小
    int* number = (int*)malloc(sizeof(int)*10000);
    //length是一维数组的长度
    int* length = (int*)malloc(sizeof(int));
    *length = 0;
    Preoder_trave(root,number,length);
c 复制代码
void Preoder_trave(struct TreeNode* root,int* number,int* length)
{
    if(root == NULL)
        return;
    number[(*length)++] = root->val;
    Preoder_trave(root->left,number,length);
    Preoder_trave(root->right,number,length);
}

2.然后我们再用qsort排序:

c 复制代码
qsort(number,*length,sizeof(int),intcompare);
int intcompare(const void* a,const void* b)
{
    return (*(int*)a - *(int*)b);
}

3.然后我们再用for循环遍历,就能找到第k个最小值了^ _ ^

c 复制代码
    int i = 0;
    for(i = 0;i < *length;i++)
    {
        if(i == k - 1)
        {
            return number[i];
        }
    }

全部代码如下图所示:

c 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
int intcompare(const void* a,const void* b)
{
    return (*(int*)a - *(int*)b);
}
void Preoder_trave(struct TreeNode* root,int* number,int* length)
{
    if(root == NULL)
        return;
    number[(*length)++] = root->val;
    Preoder_trave(root->left,number,length);
    Preoder_trave(root->right,number,length);
}
int kthSmallest(struct TreeNode* root, int k) {
    int* number = (int*)malloc(sizeof(int)*10000);
    int* length = (int*)malloc(sizeof(int));
    *length = 0;
    Preoder_trave(root,number,length);
    qsort(number,*length,sizeof(int),intcompare);
    int i = 0;
    for(i = 0;i < *length;i++)
    {
        if(i == k - 1)
        {
            return number[i];
        }
    }
    return 0;
}

好了,这就是我此题的方法,大家如果觉得好理解,就给个免费的赞吧,谢谢各位看官了^ _ ^

相关推荐
aichitang20241 分钟前
矩阵详解:从基础概念到实际应用
线性代数·算法·矩阵
OpenCSG1 小时前
电子行业AI赋能软件开发经典案例——某金融软件公司
人工智能·算法·金融·开源
chao_7891 小时前
链表题解——环形链表 II【LeetCode】
数据结构·leetcode·链表
dfsj660112 小时前
LLMs 系列科普文(14)
人工智能·深度学习·算法
薛定谔的算法2 小时前
《盗梦空间》与JavaScript中的递归
算法
kaiaaaa2 小时前
算法训练第十一天
数据结构·算法
?!7142 小时前
算法打卡第18天
c++·算法
springfe01013 小时前
构建大顶堆
前端·算法
凌辰揽月3 小时前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
lifallen3 小时前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法