嵌入式笔试刷题(第9天)

11. 怎样检测链表是否存在循环(只读内存,内存有限)

解法:快慢指针法(Floyd 判圈法)

struct Node {
    int val;
    struct Node *next;
};

int has_cycle(struct Node* head) {
    struct Node *slow = head, *fast = head;
    while (fast && fast->next) {
        slow = slow->next;
        fast = fast->next->next;
        if (slow == fast)
            return 1; // 存在环
    }
    return 0; // 无环
}


**优点:**不需要修改链表,不使用额外空间,适用于只读内存和内存受限情况。

12. C++ 中 struct 和 class 的区别

成员权限默认

public

private

继承权限默认

public

private

其他特性支持

支持构造/析构/继承

支持构造/析构/继承

总结:struct 与 class 本质相同,仅默认访问权限不同。

13. C++ 中 malloc 与 new 的区别

属于哪种语言

C语言

C++语言

是否调用构造函数

是否类型安全

否,需强制转换

是否能重载

可以

报错方式

返回 NULL

抛出异常(bad_alloc)

14. 什么是“引用”?声明和使用“引用”要注意哪些问题?

引用(Reference):是变量的别名,必须初始化,不能重新绑定。

int a = 10;
int &ref = a; // ref 是 a 的引用


注意事项:

  • 引用必须初始化;
  • 引用不能为 NULL;
  • 不能重新引用另一个变量;
  • 可用于函数参数/返回值优化性能。

15. 什么时候使用“常引用”?

常引用:const Type&,常用于:

  • 避免复制大对象(如 std::stringstd::vector);
  • 防止函数修改参数;
  • 函数返回值时引用内部数据。

示例:

void printString(const std::string& str);

更多内容全在下方专栏

全网最受欢迎的嵌入式笔试专栏

笔试专栏包含全部最新的笔试必考考点,非常适合在找工作面经薄弱的同学

3000+订阅还会涨价,提前订阅提前享受,持续更新中。

专栏链接:https://www.nowcoder.com/creation/manager/columnDetail/mPZ4kk

#嵌入式测试,嵌入式开发##嵌入式笔面经分享##面试经验谈#
全部评论

相关推荐

2025-12-18 11:59
广州南方学院 C++
牛客78682892...:直接点还好,总比要了简历也不回的强
点赞 评论 收藏
分享
Tom哥981:这份简历是“大一新生硬凹资深后端”的典型反面教材,槽点离谱到能让面试官直接笑出声: ### 1. 「年龄+入学时间」和项目复杂度完全脱节,可信度直接归0 你2024年7月才入学(现在刚读了1年多),19岁的大一新生,能把Vue3+Spring Boot+ShardingSphere+K8s+AI这些技术全塞进两个项目里?别说实际开发,光把这些技术的文档看完都得半年——这不是“能力强”,是“把招聘JD里的技术词全抄过来造假”,明摆着没碰过实际代码
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务