反转链表(包括输入输出,ACM,白板敲代码,快手面试)

本文记录了一次在快手面试中遇到的手撕代码环节,内容涉及如何从数据结构的角度来反转链表。不同于常见的ACM题目,这次面试更注重基础和理解,适合共同学习。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近面试快手,手撕代码的时候发现既不是关键代码模式也不是ACM,而是从数据结构开始写起,有点懵。记录在此,一起学习!

//链表结构体
class ListNode{
   
    int val;
    ListNode next=null;
    ListNode(int val){
   
        this.val = val;
    
### C语言结构体初始化方法 在C语言中,结构体是一种复合数据类型,可以用来存储不同类型的数据。为了正确使用结构体,必须对其进行初始化。以下是常见的几种初始化方法及其示例。 #### 1. **顺序初始化** 按照成员定义的顺序依次赋初值给各个成员。如果只需要初始化部分成员,则未初始化的部分会保持默认值(通常是0或空字符)。需要注意的是,一旦某个成员被跳过,后续成员也不能再初始化[^3]。 ```c struct Test { int a; int b; char c; double d; }; // 定义并初始化结构体变量test1 struct Test test1 = {1, 2}; // 此处a=1,b=2,c和d取默认值(通常为0) ``` #### 2. **指定成员初始化** 从C99标准起支持通过指定成员名的方式进行初始化。这种方式更加灵活,允许任意次序初始化,并且可以选择性忽略某些成员[^4]。 ```c struct Test { int a; int b; char c; double d; }; // 使用指定成员方式初始化结构体变量test2 struct Test test2 = {.b = 3, .c = 'X', .d = 78.5}; // 这里a未显式设置,默认为0 ``` #### 3. **动态内存分配后的初始化** 当利用`malloc()`或其他动态分配函数创建结构体实例时,需手动完成其内部各字段的设定工作。此时无法直接采用大括号列表形式来实现整体初始化,而应逐一访问每个域来进行具体数值赋予操作。 ```c #include <stdlib.h> struct Student { char c; int score; char* name; }; void initializeStudent(struct Student *stu){ stu->c = 'A'; stu->score = 95; stu->name = "Tom"; } int main(){ struct Student *pStu = (struct Student *) malloc(sizeof(struct Student)); if(pStu != NULL){ initializeStudent(pStu); printf("c = %c, score = %d, name = %s\n", pStu->c, pStu->score, pStu->name); free(pStu); } } ``` 上述代码展示了如何先申请一块堆空间用于存放一个新的学生记录对象,之后调用辅助函数对其属性加以配置最后打印出来验证效果同时记得释放资源防止泄露问题发生。 ### 总结 综上所述,在实际开发过程中可以根据需求选用不同的初始化策略以满足特定场景下的应用要求。无论是静态声明还是运行期间构建出来的实体都可以找到合适的办法去处理它们各自的初始状态调整事宜[^1][^2].
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值