C语言 | Leetcode C语言题解之第108题将有序数组转换为二叉搜索树

题目:

题解:

cpp 复制代码
struct TreeNode* helper(int* nums, int left, int right) {
    if (left > right) {
        return NULL;
    }

    // 选择任意一个中间位置数字作为根节点
    int mid = (left + right + rand() % 2) / 2;

    struct TreeNode* root = (struct TreeNode*)malloc(sizeof(struct TreeNode));
    root->val = nums[mid];
    root->left = helper(nums, left, mid - 1);
    root->right = helper(nums, mid + 1, right);
    return root;
}

struct TreeNode* sortedArrayToBST(int* nums, int numsSize) {
    return helper(nums, 0, numsSize - 1);
}
相关推荐
@老蝴1 小时前
C语言 — 通讯录模拟实现
c语言·开发语言·算法
TGB-Earnest4 小时前
【leetcode-合并两个有序链表】
javascript·leetcode·链表
GEEK零零七4 小时前
Leetcode 3299. 连续子序列的和
算法·leetcode·动态规划
蒟蒻小袁5 小时前
力扣面试150题--单词接龙
算法·leetcode·面试
学习噢学个屁6 小时前
基于STM32汽车温度空调控制系统
c语言·stm32·单片机·嵌入式硬件·汽车
共享家95277 小时前
c语言(重点)
c语言·数据结构·算法
iCxhust7 小时前
汇编字符串比较函数
c语言·开发语言·汇编·单片机·嵌入式硬件
玉米的玉*」*7 小时前
【每日likou】704. 二分查找 27. 移除元素 977.有序数组的平方
数据结构·算法·leetcode
我命由我123459 小时前
STM32 开发 - 中断案例(中断概述、STM32 的中断、NVIC 嵌套向量中断控制器、外部中断配置寄存器组、EXTI 外部中断控制器、实例实操)
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·嵌入式
宋一平工作室10 小时前
单片机队列功能模块的实战和应用
c语言·开发语言·stm32·单片机·嵌入式硬件