本题要求实现一个函数,用malloc生成2个结点,然后将两个结点串接起来,然后输出2个结点的值。
提示:必须采用指针进行链接,不通过链接而直接输出值来凑答案,是不得分的。输出已写在主函数里。
函数接口定义:
ptr Connect (int x1,int x2);
返回值为第一个结点的地址。x1,x2为两个data需要用到的值。只需要实现Connet函数。
结构定义:
typedef struct node//结构体定义
{ int data;//存储数据
struct node *next;//指向下一个结点的指针
}
snode,*ptr;//定义别名
裁判测试程序样例:
#include <stdio.h>
#include<stdlib.h>
typedef struct node//结构体定义
{ int data; struct node *next; }snode,*ptr;
ptr Connect (int x1,int x2);
int main() {
int x1,x2; ptr p;
scanf("%d%d",&x1,&x2);
p=Connect ( x1,x2);
printf("%d %d",p->data,p->next->data);
return 0; }
/* 请在这里填写答案 */
输入样例:
5 1
输出样例:
5 1
代码实现:
ptr Connect (int x1,int x2)
{
ptr p1 = (ptr)malloc(sizeof(snode));
ptr p2 = (ptr)malloc(sizeof(snode));
p1->data = x1;
p2->data = x2;
p1->next = p2;
return p1;
}