答疑解惑必采纳 2021-08-04 20:54 采纳率: 91.3%
浏览 51
已结题

C语言删除链表的倒数第二个元素,补全一下这个代码

img
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>

struct node {
struct node *next;
int data;
};

struct node *delete_second_last(struct node *head);
struct node *strings_to_list(int len, char *strings[]);
void print_list(struct node *head);

// DO NOT CHANGE THIS MAIN FUNCTION

int main(int argc, char *argv[]) {
// create linked list from command line arguments
struct node *head = strings_to_list(argc - 1, &argv[1]);

struct node *new_head = delete_second_last(head);
print_list(new_head);

return 0;

}

//
// Delete the second last node in the list.
// The deleted node is freed.
// The head of the list is returned.
//
struct node *delete_second_last(struct node *head) {

// PUT YOUR CODE HERE (change the next line!)
return NULL;

}

// DO NOT CHANGE THIS FUNCTION
// create linked list from array of strings
struct node *strings_to_list(int len, char *strings[]) {
struct node *head = NULL;
for (int i = len - 1; i >= 0; i = i - 1) {
struct node *n = malloc(sizeof (struct node));
assert(n != NULL);
n->next = head;
n->data = atoi(strings[i]);
head = n;
}
return head;
}

// DO NOT CHANGE THIS FUNCTION
// print linked list
void print_list(struct node *head) {
printf("[");

for (struct node *n = head; n != NULL; n = n->next) {
    // If you're getting an error here,
    // you have returned an invalid list
    printf("%d", n->data);
    if (n->next != NULL) {
        printf(", ");
    }
}
printf("]\n");

}

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-08-04 21:18
    关注
    struct node *delete_second_last(struct node *head) {
        struct node *p = head;
        if(p == NULL)
            return head;
        struct node *q  = p->next;
        if(q == NULL)
          return head;
        if(q->next == NULL)
       {
            free(p);
            return q;
       }
       struct node *m  = q->next;
       while(m != NULL)
       {
            p = q;
            q = m;
            m = m->next;
            if(m == NULL)
            {
                  p->next = m;
                  free(q);
                  break;
            }
        }
        return head;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月12日
  • 已采纳回答 8月4日
  • 创建了问题 8月4日

悬赏问题

  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 angular开发过程中,想要读取模型文件,即图1的335行,会报404错误(如图2)。但我的springboot里配置了静态资源文件,如图3。且在该地址下我有模型文件如图4,请问该问题该如何解决呢?
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 vite打包后,页面出现h.createElement is not a function,但本地运行正常
  • ¥15 Java,消息推送配置