c语言的数据结构
‘壹’ c语言与数据结构
要学数据结构的话,最起码要先学会一门语言。。。所以,学C语言的语法结构的时候是不用学数据结构,等你掌握了C的语法后,再学C语言版的数据结构(总觉得数据结构只是一种思想,不管用什么语言描述,内涵都是一样的),学完数据结构后,再回头看看以前学过的C语言,能写出更好的程序。
‘贰’ c语言,数据结构
你那个*LinkList是结构体指针类型;注意他是类型;不是变量;
然后下面的那个L,即LinkList L 这个L是个变量,是个结构体指针变量;
等同于 struct LNode *L ;
‘叁’ 用C语言写的数据结构的定义
在C语言中,结构体(struct)指的是一种数据结构,是C语言中聚合数据类型(aggregate data type)的一类。结构体可以被声明为变量、指针或数组等,用以实现较复杂的数据结构。结构体同时也是一些元素的集合,这些元素称为结构体的成员(member),且这些成员可以为不同的类型,成员一般用名字访问。
在C语言中,定义一个结构的一般形式为:
struct结构名
{
//成员表列
};
成员表由若干个成员组成, 每个成员都是该结构的一个组成部分。对每个成员也必须作类型说明,其形式为:“类型说明符 成员名;”。成员名的命名应符合标识符的书写规定。例如:
struct stu
{
int num;
char name[20];
char sex;
float score;
};
在这个结构定义中,结构名为stu,该结构由4个成员组成。 第一个成员为num,整型变量;第二个成员为name,字符型数组;第三个成员为sex,字符型变量;第四个成员为score,浮点型变量。 应注意在括号后的分号是必不可少的。
然后,当结构定义完成后,即创建了一种数据类型,可以像int、float等内置类型一样使用,以上面定义的stu结构体来和int类型对比着看。
int a;//定义一个int类型的变量a
stu a; //定义一个stu类型的变量a
int *p; //定义一个int类型的指针p
stu *p; //定义一个stu类型的指针p
int a[10];//定义一个int类型的数组a,它有10个元素,每个元素是int类型
stu a[10];//定义一个stu类型的数组a,它有10个元素,每个元素是stu类型。
‘肆’ c语言的数据结构是什么
根据你的问题,我想一种计算机语言的数据结构,是指这种语言系统所提供的,在程序中存储数据可以使用的基本数据组织形式。C语言的基本数据结构除了各种数据类型的简单变量外,主要的就是数组、结构、联合。
‘伍’ c语言数据结构
#include<stdio.h>
#include<malloc.h>
#include<string.h>
struct student{ int age; char name[10]; struct student *next; } ;
void main() { struct student *p,*p1,*p2;
p1=(struct student *)malloc(sizeof(struct student)); if ( p1==NULL ) goto errorexit0;
strcpy(p1->name,"张三"); p1->age=30; p1->next=NULL;
p2=(struct student *)malloc(sizeof(struct student)); if ( p2==NULL ) goto errorexit1;
strcpy(p1->name,"李四"); p2->age=40; p2->next=NULL;
p=p1; p->next=p2;
printf("%s %s\n",p->name,(p->next)->name);
free(p1); free(p2); return;
errorexit1: free(p1); printf("申请节点2出错。\n");
errorexit0: printf("申请节点1出错。\n");
}
‘陆’ 数据结构和C语言有什么区别
数据结构是数据及数据之间的关系,C语言只是一门编程语言,可以用C语言来写程序,实现数据按照某种特定的关系来组织和管理数据(也就是实现数据结构),所以数据结构的课程会有不同的语言版本,其实就是用不同的语言来实现数据结构了。呵呵,不知道你明白没有呢~~
‘柒’ c语言的数据结构
你真有意思,什么叫C语言的数据结构?数据结构是所有语言所共有的好吧!就像你说话想表达一个意思一样,你可以用汉语说,也可以用日语说,还可以用英语说。
简单的说,数据结构分两个部分:
存储表示和抽象表示。存储表示就是元素在内存中的真实物理表示。抽象表示就是忽略元素的存储表示,只研究它的抽象属性。比如说表,抽象意义上,就是表;存储上来说,分成顺序表,也就是数组,和链表。
‘捌’ c语言数据结构
100个元素进行排序,每个元素需要和其他元素进行比较,比较之后需要移动位置。
所以,这个题目的要求是:
首先进行排序(排序的方法有两种:顺序查找,二分查找,两种都要实现)
在处理排序的过程中,每个元素需要比较和移位,你需要统计一下每个元素比较移位的次数(针对1中描述的两种方法分别统计,然后做对比)
‘玖’ C语言 数据结构
第一处:s->next=q->next;改为
s->next = p;
因前一句为q->next=s;
连起来相当于s->next = s;
这样的链表是有一个环的,插入后再遍历会导致死循环。
或者可以这样把两句倒过来写:
s->next=q->next;
q->next=s;
两种选一个。
第二处:
free(p);
插入一个节点无需free任何东西,因原有所有节点都需要保留。