求问个c语言问题(数据结构),如下顺序表的添加元素的函数 为什么这样写不行

比如typedef struct{

elemtype *elem;

int length;
}sqlist;

sqlist L;
可以memset(L.elem,-10,sizeof(*L.elem));吗

第1个回答  推荐于2017-09-29
可是可以,但你这样做的目的是什么呢?例如:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef char elemtype;
typedef struct {

elemtype *elem;
int length;
}sqlist;

int
main(void)
{
sqlist L;
memset(L.elem,-10,sizeof(*L.elem));
printf("*L.elem=%d\n",*L.elem);
return 0;
}追问

就像往顺序表里添加元素啊 当该位置值为-10时代表该位置待添加。可是我这样写运行时会崩溃

追答

你这是要定义一个链表吗?定义链表的话至少还差一个域吧,要不然怎么表示链接关系呢,你出这个错误可能是因为你的elemtype *不是字符串型的,那样memset就没法进行操作了,memset一般是针对字符串的,所以你的struct中的元素也必须是字符串才行。

追问

不是链表是顺序表

不会啊 memset对整型也行啊 我这里是整型 而且以前也这样初始化过数组

追答

memset(void *s,int c,size_t n)是把s所指的一块内存区域的前n字节置为c,也就是说,如果你的*s不是字符指针型的,有可能得不到你要的结果,即便程序运行不出错,对你来说也没什么意义呢。

本回答被提问者和网友采纳
第2个回答  2015-04-26
c语言没有memset吧,用malloc申请空间吧
相似回答