单链表 C语言 学习记录】的更多相关文章

概念 链接方式存储 链接方式存储的线性表简称为链表(Linked List). 链表的具体存储表示为: 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的,也可以是不连续的). 链表中结点的逻辑次序和物理次序不一定相同.为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link)). 链式存储是最常用的存储方式之一,它不仅可用来表示线性表,而且可用来表示各种非线性的数据结构. 单链表 单链表是一种…
/***************************************************** Author:Simon_Kly Version:0.1 Date: 20170520 Description:循环单链表 Mail:degaullekong@gmail.com Funcion List: *****************************************************/ #include <stdio.h> #include <std…
/***************************************************** Author:Simon_Kly Version:0.1 Date:20170520 Description:带头接点的单链表 Mail:degaullekong@gmail.com Funcion List: *****************************************************/ #include <stdio.h> #include <s…
File name:no_head_link.c Author:SimonKly Version:0.1 Date: 2017.5.20 Description:不带头节点的单链表 Funcion List: *****************************************************/ #include <stdio.h> #include <stdlib.h> typedef struct node { int id; struct node *…
包括初始化,创建,查询,长度,删除,清空,销毁等操作 代码如下: #include<stdio.h> #include<stdlib.h> //定义单链表的数据类型 typedef struct book { char name[10]; char code[10]; float price; }book; typedef book Book; //定义单链表 typedef struct LNode { Book data; struct LNode *next; }LNode,…
c语言基础学习 int num1 = 15; int num2 = 5; int temp = 0; //先把num1放到temp里 temp = num1; //先把num2放到num1里 num1 = num2; //先把temp放到num2里 num2 = temp; 算数运算符 +加法运算 -减法运算符 *乘法运算符 /除法运算符  ------整型相除取整,除数不为0 %取余运算符 ------两边均为整数 ++递增运算-------运算符在前,先执行:运算符在后,后执行: --递减运…
sizeof:给出某个类型或某个变量在内存中占据的字节数:(1个字节8位,即8比特) 格式符 (1)%ld表示数据按十进制有符号长型整数输入或输出. (2)%d表示数据按十进制有符号整型数输入或输出. (3)%u表示数据按十进制无符号整型数输入或输出. &:取得变量的地址:且必须对"变量"来取地址: 0x:16进制表示法: C语言的内存分配为堆栈的自顶向下来分配的,地址逐渐减小: 数组A[ ]的地址:&a==a==&a[0]; 指针:指针变量就是用来记录地址的变…
逻辑性变量的定义符:bool,在C语言中只有true和false: 定义方式:bool t = true; 逻辑运算符: !:逻辑非 &&:逻辑与 ||:逻辑或 表达区间的错误形式:4<x<6;(由左到右顺序执行) 表达区间的正确形式:x>4&&x<6; 判断大写字母:c>='A'&& c<='Z'; 单目运算符的优先级高于双目运算符: 例:!age<20;-------->  (!age)<20;  …
思路: 工具书: <c程序设计语言> R&K <linux C 编程一站式学习>…
偶尔看到大一时候写了一个多级链表,听起来好有趣,稍微整理一下. 稍微注意一下两点: 1.指针是一个地址,他自己也是有一个地址.一级指针(带一个*号)表示一级地址,他自身地址为二级地址.二级指针(带两个*号)表示二级地址,他自身地址为三级地址. 那么n级指针表示(带n个*号)表示n级地址,他自身是一个n+1级地址. { ); // p1为一级地址 // &p1 自身地址为二级地址. //类似 int **p2 = &p; // p2为二级地址 // &p2 自身地址为三级地址. }…
几天前某宝买了一套,这几天没工夫.今天开始学学这个“玩具”. 1.Arduino的变量数据类型: 数据类型  数据类型 RAM 范围 void keyword N/A N/A boolean 1 byte 0 到 1(True 或 False) byte 1 byte 0 到 255 char 1 byte -128 到 127 unsigned char 1 byte 0 到 255 int 2 byte -32768 到 32767 unsigned int 2 byte 0 到 65535…
各种语句及编程笔记记录 1.if & else #include<stdio.h> int main(){     int if (situation) {         //model; } else  {         //mode2; } prinf("?\n")     return 0; } 2.if & else(a>60) #include<stdio.h> int main() {     int a=100; if (…
char类型的输出: scanf("%d",&i);//i=49; char x=i; printf("x=%d\n",x); printf("x='%c'\n",c); 得到 x=49 x='1' 即x=49的值,作为整数输出的时候值为49,作为char类型变量的时候,值为1(1的ASCLL码为49),得到'1'==49,此时1为字符值,49为值: scanf("%d",x);//从输入里面读入整数: scanf(&…
"学计算机一定要有一个非常强大的心理状态,计算机不是黑魔法,都是人想出来的,别人能够想的出来,那么,总有一天,我也能够想的出来." 指针类型的变量就是保存地址的变量. int* p=&i;------P是一个指针,P里面的内容为变量i的地址,即说P指向了i: int* p,q;------注意:*号仅仅加给了p,即语句意思为p为指针,而q为普通的整数类型:(c语言中无int*  这个类型) %P:指针类型格式: 运算符*:单目运算符,用来访问指针的值所表示的地址上的变量:即地址…
C99开始,可以用变量来定义数组的大小:例如,利用键盘输入的变量来定义数组大小: 赋值号左边的值叫做左值: 关于数组:编译器和运行环境不会检查数组下标是否越界,无论读还是写. 越界数组可能造成的问题提示语:segmentation fault 程序员的责任:有效的下标值:[0,数组的大小-1] 例:如下字符可以作下标 int a[255]; a['A'] = 1; 因为A的ascll码值小于255: 安全的做法:数组使用之前初始化数组: 函数的好处:把功能单纯且代码量大的部分封装为函数,提高可视…
switch只能判断整数,而分段函数的判别是一个范围,我们无法用整数来表示范围 跟踪语句的方法: (1)debug调试 (2)printf( )语句跟踪 小套路:当循环次数很大时,可以先模拟较小次数的循环,然后做出检验和判断. rand( ):随机数产生函数,得到一个随机的整数. 例:等到1--100的随机数: #include<stdlib.h> #include<time.h>   srand(time()); int a = rand( )%100+1; x%n------&…
变量在第一次被使用之前应该赋初值 scanf(“%d”,&price); scanf(“price%d %d”,&price);  scanf中的东西一定是要输入的东西. 定义常量:const int amount=100;为数字起名字更加易于理解数字的含义:便于修改:赋初值之后不能再修改:const变量一般大写: 两个整数运算的结果只能是整数,小数部分扔掉. %d:表达整数类型输入和输出:%f:表达浮点数输出:%lf:表达浮点数输入: 浮点数:带小数点的数,小数点的位置可以浮动. 改进方…
C语言的灵魂:指针 #include <stdio.h> int main(int argc, char **argv) {  printf("Hello, World!\n"); int i=5;   scanf("%d", &i); printf("%d", i+20); return 0; } 推荐编程软件:Dev-c++ 程序框架 #include <stdio.h> int main() {  retur…
4.对象改值 4.1.就地改值 比如: vec <- c(0,0,0,0,0,0,0) vec[1]<-100 #vec向量的第一个值就变为100 ####对于数据框的改值的方法,如下面的例子 df <- data.frame(face=c("ace","two","six"),suit=c("clubs","clubs","clubs"),values=c(1,2,3…
1.&& || ! 与或非-逻辑运算符,&&的优先级大于||.…
1. while语句 2. 循环嵌套 3. 数组 4. 排序 1. while 由于上节课时间有限,介绍完for循环后没有来得及讲while语句.简单来讲,while也是一种循环结构,先看一个例子: int i = 0; while (i < 10) { printf("%d\n", i); i++; } 这是一个输出0-9的程序片段. 与for一样,while后面是一个空格加一对小括号,小括号里面是循环执行的条件. 程序先判断是否满足小括号内的条件:如果满足条件,就执行大括号中…
打印字符串:%s--------printf("%s","abcd"); 打印字符串数组中某一位:%c--------printf("%c","abcd[2]"); 字符的定义及打印格式: struct { int amount; char *name; }coins[] = { {,"one"}, {,"two"}, {,"three"} }; char *abc=…
\n:换行:   \t:制表符,相当于大空格: a[5]={2};<------->a[5]={2,0,0,0,0}; 数组初始化的方法:a[5]={0};即全部初始化为0: 数组初始化的定位初始化(C99):int a[6]={[0]=2,[2]=2,3,};<------>a[0]=2,a[2]=2,a[3]=3,其余全部初始化为0: sizeof:得出变量或数组的大小:当对象是数组时,单位为字节,即整个数组所占空间的字节大小. 求数组的元素的个数:i=sizeof(a)/si…
break语句的作用:当执行到break,则跳出循环,免去不必要的循环次数,节省时间和资源.-----跳出循环,结束循环: continue:跳过这一次循环剩下的语句,进入到下一轮循环.-----跳到下一次循环: break不足:只能跳出其所在的循环,不能跳出嵌套的循环:continue也是: 上一条问题的解决办法:接力break: go to 语句:  解决难以跳出多重嵌套的问题. 格式: go to 标号: 标号:-- : 关于go to 语句使用的建议:建议只在跳出多重嵌套的场合使用go…
优先级:算术运算符 > 关系运算符 > 赋值 ==和!=的优先级低于其他关系运算符 连续的关系运算符从左到右进行 注释:“//”或“/**/” 判断语句:if else 写代码有时看重的是你能否让足够多的人读懂你的代码 if语句形式: (1)if ( )  {语句:} (2) if  ( )  语句:以句号为结束标志:没有大括号的话,只有紧跟在if 和else后面的那一句代码有效.因为if和else后面都只执行一句话,要想执行多个语句及必须加上大括号,所以总的来说加上大括号是最好的 读入输入数…
1.set & unset %set a Hello ;#定义变量 a 并赋值 =>Hello %puts $a ;#输出变量值 =>Hello %set a “Test Tcl” ;#重新赋值 =>Test Tcl %set a ;#输出变量值,此时不加”$” => Test Tcl %puts $a ;#输出变量值,此时要加”$” =>Test Tcl %puts a ;#输出字符”a” => a %set b $a ;#将 a 的值赋给 b =>Te…
先来一个返回指针的测试,结果跟想象一样 type A map[int]string type B struct { A c int } func main() { b := B{make(A), 10} NewB := func() *B { return &b } c := NewB() c.c = 100 c.A[1] = "3" fmt.Println(b, c) } /* output {map[1:3] 100} &{map[1:3] 100} */ 再试试直…
(R基础) 对象:什么是对象呢,其实就是一个名称而已,在R中存储的数据 就是一个R对象 a <- 1 ###其中'<-'表示的是一个赋值符号 这句话表示的是,将1赋值给a b <- 1:6 #返回的是 1 2 3 4 5 6 #还要注意的是,首先对象名称不能够以数字开头,其次一些特殊的符号不能在名称中出现 如 !, $, ^,@,+,-,/,* ,并且实区分大小写的,同一个对象再次被赋值的话,R会覆盖存储在对象中的信息. c <- 1:2 c %o% c #矩阵相乘 round #…
本学习是基于嵌入式的C语言学习记录(课程内容来源于某位老师的网络课程,为了证明不是在打广告,就不写出老师的名字了,感谢.) -------------------------------------------------- 首先弄明白程序是什么?计算机为什么需要编程? 编写程序的目的是为了去运行,从而得到一些结果.顾名思义计算机就是用来计算的,所以计算机的所有程序就是在计算,那么计算机在计算什么呢?当然是在计算数据,因此,数据是程序的重要组成.推出:计算机程序 = 代码 + 数据.那么程序运行…
单链表 就好比火车 火车头-->链表头部火车尾-->链表尾部火车厢-->链表的节点火车厢连接的部分-->指针火车中的内容-->链表节点的的数据链表节点包含数据域和指针域数据域存放数据指针域存放要连接的节点的首地址 在造火车的时候 先是火车头 然后是车厢--->链表的首节点和之后的节点 先从内存中申请头结点的存储空间--->PLTST phead=(PLTST)malloc(sizeof(LTST));首节点在创建时会让指针域指向空--->既链表的初始化 链表…