From 7ba41a35c65995ba5de6844d3bc22721ca7fd6a8 Mon Sep 17 00:00:00 2001
From: Didnelpsun <2675350965@qq.com>
Date: Fri, 13 Aug 2021 11:02:33 +0800
Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=E4=BB=A3=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.gitignore | 12 +-
Code/C-Code/C-Code.sln | 31 ++
Code/C-Code/C-Code.vcxproj | 153 +++++++++
Code/C-Code/C-Code.vcxproj.filters | 36 ++
.../C-Code.vcxproj.user} | 0
{CPP-Code => Code/C-Code}/head/head.h | 0
Code/C-Code/head/link_list.h | 114 +++++++
Code/C-Code/head/sequence_list.h | 322 ++++++++++++++++++
Code/C-Code/source/main.c | 10 +
Code/C-Code/source/test.c | 45 +++
{CPP-Code => Code/CPP-Code}/CMakeLists.txt | 0
.../CPP-Code}/CMakeSettings.json | 0
Code/{ => CPP-Code/head}/head.h | 0
{CPP-Code => Code/CPP-Code}/head/link_list.h | 0
.../CPP-Code}/head/sequence_list.h | 0
{CPP-Code => Code/CPP-Code}/source/main.cpp | 0
{CPP-Code => Code/CPP-Code}/source/test.cpp | 0
Code/{ => Code}/Code.sln | 0
Code/{ => Code}/Code.vcxproj | 0
Code/{ => Code}/Code.vcxproj.filters | 0
Code/Code/Code.vcxproj.user | 4 +
Code/{ => Code}/double_link_list.h | 0
Code/{ => Code}/graph.h | 0
Code/Code/head.h | 8 +
Code/{ => Code}/link_list.h | 0
Code/{ => Code}/link_queue.h | 0
Code/{ => Code}/link_stack.h | 0
Code/{ => Code}/link_string.h | 0
Code/{ => Code}/link_tree.h | 0
Code/{ => Code}/main.c | 0
Code/{ => Code}/search.h | 0
Code/{ => Code}/sequence_list.h | 0
Code/{ => Code}/sequence_queue.h | 0
Code/{ => Code}/sequence_stack.h | 0
Code/{ => Code}/sequence_string.h | 0
Code/{ => Code}/sequence_tree.h | 0
Code/{ => Code}/sort.h | 0
Code/{ => Code}/static_link_list.h | 0
Code/{ => Code}/test.c | 0
Code/{ => Code}/thread_tree.h | 0
Operate-System/0-summary-ex.md | 20 ++
41 files changed, 749 insertions(+), 6 deletions(-)
create mode 100644 Code/C-Code/C-Code.sln
create mode 100644 Code/C-Code/C-Code.vcxproj
create mode 100644 Code/C-Code/C-Code.vcxproj.filters
rename Code/{Code.vcxproj.user => C-Code/C-Code.vcxproj.user} (100%)
rename {CPP-Code => Code/C-Code}/head/head.h (100%)
create mode 100644 Code/C-Code/head/link_list.h
create mode 100644 Code/C-Code/head/sequence_list.h
create mode 100644 Code/C-Code/source/main.c
create mode 100644 Code/C-Code/source/test.c
rename {CPP-Code => Code/CPP-Code}/CMakeLists.txt (100%)
rename {CPP-Code => Code/CPP-Code}/CMakeSettings.json (100%)
rename Code/{ => CPP-Code/head}/head.h (100%)
rename {CPP-Code => Code/CPP-Code}/head/link_list.h (100%)
rename {CPP-Code => Code/CPP-Code}/head/sequence_list.h (100%)
rename {CPP-Code => Code/CPP-Code}/source/main.cpp (100%)
rename {CPP-Code => Code/CPP-Code}/source/test.cpp (100%)
rename Code/{ => Code}/Code.sln (100%)
rename Code/{ => Code}/Code.vcxproj (100%)
rename Code/{ => Code}/Code.vcxproj.filters (100%)
create mode 100644 Code/Code/Code.vcxproj.user
rename Code/{ => Code}/double_link_list.h (100%)
rename Code/{ => Code}/graph.h (100%)
create mode 100644 Code/Code/head.h
rename Code/{ => Code}/link_list.h (100%)
rename Code/{ => Code}/link_queue.h (100%)
rename Code/{ => Code}/link_stack.h (100%)
rename Code/{ => Code}/link_string.h (100%)
rename Code/{ => Code}/link_tree.h (100%)
rename Code/{ => Code}/main.c (100%)
rename Code/{ => Code}/search.h (100%)
rename Code/{ => Code}/sequence_list.h (100%)
rename Code/{ => Code}/sequence_queue.h (100%)
rename Code/{ => Code}/sequence_stack.h (100%)
rename Code/{ => Code}/sequence_string.h (100%)
rename Code/{ => Code}/sequence_tree.h (100%)
rename Code/{ => Code}/sort.h (100%)
rename Code/{ => Code}/static_link_list.h (100%)
rename Code/{ => Code}/test.c (100%)
rename Code/{ => Code}/thread_tree.h (100%)
diff --git a/.gitignore b/.gitignore
index 8596ef1..fd077bc 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,7 +1,7 @@
*.pdf
-*/.vs/
-*/.idea/
-*/Debug/
-*/x64/
-*/out/
-*/cmake-build-debug/
\ No newline at end of file
+*.vs/
+*.idea/
+*Debug/
+*x64/
+*out/
+*cmake-build-debug/
\ No newline at end of file
diff --git a/Code/C-Code/C-Code.sln b/Code/C-Code/C-Code.sln
new file mode 100644
index 0000000..7383438
--- /dev/null
+++ b/Code/C-Code/C-Code.sln
@@ -0,0 +1,31 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 16
+VisualStudioVersion = 16.0.31605.320
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "C-Code", "C-Code.vcxproj", "{0097210B-6B4C-4528-90F7-28DC333772CF}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|x64 = Release|x64
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Debug|x64.ActiveCfg = Debug|x64
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Debug|x64.Build.0 = Debug|x64
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Debug|x86.ActiveCfg = Debug|Win32
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Debug|x86.Build.0 = Debug|Win32
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Release|x64.ActiveCfg = Release|x64
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Release|x64.Build.0 = Release|x64
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Release|x86.ActiveCfg = Release|Win32
+ {0097210B-6B4C-4528-90F7-28DC333772CF}.Release|x86.Build.0 = Release|Win32
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {D42A6D35-5080-4B03-A977-17AEC5B1ED3D}
+ EndGlobalSection
+EndGlobal
diff --git a/Code/C-Code/C-Code.vcxproj b/Code/C-Code/C-Code.vcxproj
new file mode 100644
index 0000000..45af98f
--- /dev/null
+++ b/Code/C-Code/C-Code.vcxproj
@@ -0,0 +1,153 @@
+
+
+
+
+ Debug
+ Win32
+
+
+ Release
+ Win32
+
+
+ Debug
+ x64
+
+
+ Release
+ x64
+
+
+
+ 16.0
+ Win32Proj
+ {0097210b-6b4c-4528-90f7-28dc333772cf}
+ CCode
+ 10.0
+
+
+
+ Application
+ true
+ v142
+ Unicode
+
+
+ Application
+ false
+ v142
+ true
+ Unicode
+
+
+ Application
+ true
+ v142
+ Unicode
+
+
+ Application
+ false
+ v142
+ true
+ Unicode
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ true
+
+
+ false
+
+
+ true
+
+
+ false
+
+
+
+ Level3
+ true
+ WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+ Level3
+ true
+ _DEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+
+
+
+
+ Level3
+ true
+ true
+ true
+ NDEBUG;_CONSOLE;%(PreprocessorDefinitions)
+ true
+
+
+ Console
+ true
+ true
+ true
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Code/C-Code/C-Code.vcxproj.filters b/Code/C-Code/C-Code.vcxproj.filters
new file mode 100644
index 0000000..7cac836
--- /dev/null
+++ b/Code/C-Code/C-Code.vcxproj.filters
@@ -0,0 +1,36 @@
+
+
+
+
+ {4FC737F1-C7A5-4376-A066-2A32D752A2FF}
+ cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx
+
+
+ {93995380-89BD-4b04-88EB-625FBE52EBFB}
+ h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd
+
+
+ {67DA6AB6-F800-4c08-8B7A-83BB121AAD01}
+ rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms
+
+
+
+
+ 源文件
+
+
+ 源文件
+
+
+
+
+ 头文件
+
+
+ 头文件
+
+
+ 头文件
+
+
+
\ No newline at end of file
diff --git a/Code/Code.vcxproj.user b/Code/C-Code/C-Code.vcxproj.user
similarity index 100%
rename from Code/Code.vcxproj.user
rename to Code/C-Code/C-Code.vcxproj.user
diff --git a/CPP-Code/head/head.h b/Code/C-Code/head/head.h
similarity index 100%
rename from CPP-Code/head/head.h
rename to Code/C-Code/head/head.h
diff --git a/Code/C-Code/head/link_list.h b/Code/C-Code/head/link_list.h
new file mode 100644
index 0000000..b5efa6f
--- /dev/null
+++ b/Code/C-Code/head/link_list.h
@@ -0,0 +1,114 @@
+#include
+#include
+#include "head.h"
+
+//
+typedef struct LinkListNode {
+ element_type data;
+ struct LinkListNode* next;
+} LinkListNode, *LinkList;
+
+// CֵԱһм
+// ʼͷڵ㵥
+int InitLinkListWithHead(LinkList list) {
+ if (list) {
+ list->data = NULL;
+ list->next = NULL;
+ return 0;
+ }
+ else {
+ printf("InitLinkListWithHead:ָΪʼ");
+ return 1;
+ }
+}
+
+// CʵֳʼΪʵôݣֵܸ
+// ʼͷڵ㵥
+int InitLinkListWithoutHead(LinkList list) {
+ list = NULL;
+ return 0;
+}
+
+// ͷڵ㵥
+LinkList CreateLinkListWithHead() {
+ LinkList list = (LinkListNode*)malloc(sizeof(LinkListNode));
+ if (list) {
+ list->data = NULL;
+ list->next = NULL;
+ }
+ else {
+ printf("CreateLinkListWithHead:ռʧܣ");
+ }
+ return list;
+}
+
+// ͷڵ㵥
+LinkList CreateLinkListWithoutHead() {
+ return NULL;
+}
+
+
+// жͷڵ㵥ǷΪ
+int EmptyLinkListWithHead(LinkList list) {
+ if (list->next) {
+ return 0;
+ }
+ else {
+ return 1;
+ }
+}
+
+// жͷڵ㵥ǷΪ
+int EmptyLLinkListWithoutHead(LinkList list) {
+ if (list) {
+ return 0;
+ }
+ else {
+ return 1;
+ }
+}
+
+// ͷڵ㵥Ԫ
+// 0Žڵͷڵ
+int InsertLinkListWithHead(LinkList list, int index, element_type elem) {
+ if (index < 1) {
+ printf("InsertLinkListWithHead:ֵС\n");
+ return 1;
+ }
+ // һָpָǰɨ赽Ľ
+ LinkListNode* p;
+ // һiʾǰɨ赽Ľ
+ int i = 0;
+ // ͷָpΪ0
+ p = list;
+ // ѭָŵĵĽ
+ // ǵǰһΪŵĽһǿս
+ while (p->next != NULL && i < index - 1) {
+ p = p->next;
+ i++;
+ }
+ // ʱiСindex-1ʾ껹ûеӦ
+ if (i < index - 1) {
+ printf("InsertLinkListWithHead:ֵ\n");
+ return 1;
+ }
+ // ʱi==index-1
+ LinkListNode* s = (LinkListNode*)malloc(sizeof(LinkListNode));
+ if (s) {
+ s->data = elem;
+ // pԭĺ̸µĽ
+ s->next = p->next;
+ p->next = s;
+ return 0;
+ }
+ else {
+ printf("InsertLinkListWithHead:ڴʧܣ\n");
+ return 1;
+ }
+}
+
+// ͷڵ㵥Ԫ
+// CҲ
+int InsertLinkListWithoutHead(LinkList list, int index, element_type elem) {
+ return 1;
+}
\ No newline at end of file
diff --git a/Code/C-Code/head/sequence_list.h b/Code/C-Code/head/sequence_list.h
new file mode 100644
index 0000000..d2ad597
--- /dev/null
+++ b/Code/C-Code/head/sequence_list.h
@@ -0,0 +1,322 @@
+#include
+#include
+#include "head.h"
+
+#pragma warning(disable:6385)
+#pragma warning(disable:6386)
+
+// 静态顺序表
+typedef struct {
+ element_type data[MAXSIZE];
+ // 长度
+ int length;
+} StaticSequenceList;
+
+// 动态顺序表
+typedef struct {
+ // 给一个指针来分配动态数组
+ element_type *data;
+ // 已分配的最大容量
+ int max_size;
+ // 长度
+ int length;
+} DynamicSequenceList;
+
+// 初始化静态顺序表
+int InitStaticSequenceList(StaticSequenceList* list) {
+ if (list) {
+ // 初初始化静态顺序表长度为0
+ list->length = 0;
+ return 0;
+ }
+ else {
+ printf("InitStaticSequenceList:指针指向为NULL!\n");
+ return 1;
+ }
+}
+
+// 初始化动态顺序表
+int InitDynamicSequenceList(DynamicSequenceList* list) {
+ if (list) {
+ // 初初始化动态顺序表长度为0
+ list->length = 0;
+ list->max_size = 0;
+ // 申请一片连续的存储空间
+ element_type* space = (element_type*)malloc(MAXSIZE * sizeof(element_type));
+ if (space) {
+ list->data = space;
+ list->max_size = MAXSIZE;
+ return 0;
+ }
+ else {
+ printf("InitDynamicSequenceList:分配空间失败!\n");
+ return 1;
+ }
+ }
+ else {
+ printf("InitDynamicSequenceList:指针指向为NULL!\n");
+ return 1;
+ }
+}
+
+// 打印静态顺序表
+int PrintfStaticSequenceList(StaticSequenceList list) {
+ for (int i = 0; i < list.length; i++) {
+ printf("第%d个元素值为%c\n", i + 1, list.data[i]);
+ }
+ return 0;
+}
+
+// 打印动态顺序表
+int PrintfDynamicSequenceList(DynamicSequenceList list) {
+ for (int i = 0; i < list.length; i++) {
+ printf("第%d个元素值为%c\n", i + 1, list.data[i]);
+ }
+ return 0;
+}
+
+// 分配其他地址增长动态顺序表的数据空间长度
+int OtherIncreaseDynamicSequenceList(DynamicSequenceList* list, int len) {
+ if (len <= 0) {
+ printf("OtherIncreaseDynamicSequenceList:申请空间应该大于0!\n");
+ return 1;
+ }
+ // 申请一片连续的存储空间
+ int new_length = list->max_size + len;
+ element_type* space = (element_type*)malloc(new_length * sizeof(element_type));
+ if (space) {
+ // 建立中间变量
+ list->data = space;
+ element_type* temp = list->data;
+ for (int i = 0; i < list->length; i++) {
+ list->data[i] = temp[i];
+ }
+ list->max_size = new_length;
+ free(temp);
+ return 0;
+ }
+ else {
+ printf("OtherIncreaseDynamicSequenceList:重新分配空间失败!\n");
+ return 1;
+ }
+}
+
+// 重新分配地址增长动态顺序表的数据空间长度
+int ReIncreaseDynamicSequenceList(DynamicSequenceList* list, int len) {
+ if (len <= 0) {
+ printf("ReIncreaseDynamicSequenceList:申请空间应该大于0!\n");
+ return 1;
+ }
+ // 申请一片连续的存储空间
+ int new_length = list->max_size + len;
+ element_type* space = (element_type*)realloc(list->data, new_length * sizeof(element_type));
+ if (space) {
+ list->data = space;
+ list->max_size += len;
+ return 0;
+ }
+ else {
+ list->max_size = 0;
+ list->length = 0;
+ printf("ReIncreaseDynamicSequenceList:分配其他地址空间失败!\n");
+ return 1;
+ }
+}
+
+// 插入静态顺序表
+int InsertStaticSequenceList(StaticSequenceList* list, int index, element_type elem) {
+ // 当静态顺序表已经满了就不能插入任何元素
+ if (list->length >= MAXSIZE) {
+ printf("InsertStaticSequenceList:静态顺序表空间不足,插入失败!\n");
+ return 1;
+ }
+ // 索引位置从0开始,所以可以插入的范围是0到list->length
+ if (index > list->length || index < 0) {
+ printf("InsertStaticSequenceList:插入索引%d超过索引范围!\n", index);
+ return 1;
+ }
+ // 从最后一个元素开始交换后移,list->length是空的
+ for (int i = list->length; i > index; i--) {
+ list->data[i] = list->data[i - 1];
+ }
+ list->data[index] = elem;
+ list->length++;
+ return 0;
+}
+
+// 插入动态顺序表
+int InsertDynamicSequenceList(DynamicSequenceList* list, int index, element_type elem) {
+ if (index > list->length || index < 0) {
+ printf("InsertDynamicSequenceList:插入索引%d超过索引范围!\n", index);
+ return 1;
+ }
+ // 当动态顺序表已经满了,需要新增一个位置
+ // 为了避免索引无效而多增加一个空间,所以放在检查索引值的后面
+ if (list->length >= MAXSIZE) {
+ int result = ReIncreaseDynamicSequenceList(list, 1);
+ if (result == 1) {
+ printf("InsertDynamicSequenceList:申请空间失败!\n");
+ return 1;
+ }
+ }
+ for (int i = list->length; i > index; i--) {
+ list->data[i] = list->data[i - 1];
+ }
+ list->data[index] = elem;
+ list->length++;
+ return 0;
+}
+
+// 循环插入静态顺序表
+int LoopInsertStaticSequenceList(StaticSequenceList* list, element_type* elem, int start, int end) {
+ for (int i = 0; i < end; i++) {
+ int result = InsertStaticSequenceList(list, i, elem[i + start]);
+ if (result == 1) {
+ printf("LoopInsertStaticSequenceList:循环插入失败!\n");
+ return 1;
+ }
+ }
+ return 0;
+}
+
+// 循环插入动态顺序表
+int LoopInsertDynamicSequenceList(DynamicSequenceList* list, element_type* elem, int start, int end) {
+ for (int i = 0; i < end; i++) {
+ int result = InsertDynamicSequenceList(list, i, elem[i + start]);
+ if (result == 1) {
+ printf("LoopInsertDynamicSequenceList:循环插入失败!\n");
+ return 1;
+ }
+ }
+ return 0;
+}
+
+// 删除静态顺序表
+int DeleteStaticSequenceList(StaticSequenceList* list, int index, element_type *elem) {
+ if (index >= list->length || index < 0) {
+ printf("DeleteStaticSequenceList:删除索引超过索引范围!\n");
+ return 1;
+ }
+ *elem = list->data[index];
+ for (int i = index; i < list->length; i++) {
+ list->data[i] = list->data[i + 1];
+ }
+ list->length--;
+ return 0;
+}
+
+// 删除动态顺序表
+int DeleteDynamicSequenceList(DynamicSequenceList* list, int index, element_type *elem) {
+ if (index >= list->length || index < 0) {
+ printf("DeleteDynamicSequenceList:删除索引超过索引范围!\n");
+ return 1;
+ }
+ *elem = list->data[index];
+ for (int i = index; i < list->length; i++) {
+ list->data[i] = list->data[i + 1];
+ }
+ list->length--;
+ return 0;
+}
+
+// 删除多个静态顺序表
+int MultiDeleteStaticSequenceList(StaticSequenceList* list, int index, int len, element_type* elem) {
+ if (index + len >= list->length || index < 0) {
+ printf("MultiDeleteStaticSequenceList:删除索引超过索引范围!\n");
+ return 1;
+ }
+ for (int i = index; i < list->length - len; i++) {
+ if (i < index + len) {
+ elem[i - index] = list->data[i];
+ }
+ list->data[i] = list->data[i + len];
+ }
+ list->length -= len;
+ return 0;
+}
+
+// 删除多个动态顺序表
+int MultiDeleteDynamicSequenceList(DynamicSequenceList* list, int index, int len, element_type* elem) {
+ if (index + len >= list->length || index < 0) {
+ printf("MultiDeleteDynamicSequenceList:删除索引超过索引范围!\n");
+ return 1;
+ }
+ for (int i = index; i < list->length - len; i++) {
+ if (i < index + len) {
+ elem[i - index] = list->data[i];
+ }
+ list->data[i] = list->data[i + len];
+ }
+ list->length -= len;
+ return 0;
+}
+
+// 按位查找静态顺序表元素
+element_type GetStaticSequenceListElement(StaticSequenceList list, int index) {
+ if (index >= list.length || index < 0) {
+ printf("GetStaticSequenceListElement:查找索引超过索引范围!\n");
+ return DEFAULTELEM;
+ }
+ return list.data[index];
+}
+
+// 按位查找动态顺序表元素
+element_type GetDynamicSequenceListElement(DynamicSequenceList list, int index) {
+ if (index >= list.length || index < 0) {
+ printf("GetDynamicSequenceListElement:查找索引超过索引范围!\n");
+ return DEFAULTELEM;
+ }
+ return list.data[index];
+}
+
+// 按值查找静态顺序表索引
+int LocateStaticSequenceListElement(StaticSequenceList list, element_type elem) {
+ for (int i = 0; i < list.length; i++) {
+ if (list.data[i] == elem) {
+ return i;
+ }
+ }
+ printf("LocateStaticSequenceListElement:未能定位到对应值的元素!\n");
+ return -1;
+}
+
+// 按值查找动态顺序表索引
+int LocateDynamicSequenceListElement(DynamicSequenceList list, element_type elem) {
+ for (int i = 0; i < list.length; i++) {
+ if (list.data[i] == elem) {
+ return i;
+ }
+ }
+ printf("LocateDynamicSequenceListElement:未能定位到对应值的元素!\n");
+ return -1;
+}
+
+// 判空静态顺序表
+int EmptyStaticSequenceList(StaticSequenceList list) {
+ if (list.length == 0) {
+ return 1;
+ }
+ else {
+ return 0;
+ }
+}
+
+// 判空动态顺序表
+int EmptyDynamicSequenceList(DynamicSequenceList list) {
+ if (list.length == 0) {
+ return 1;
+ }
+ else {
+ return 0;
+ }
+}
+
+// 销毁动态顺序表
+int DestroyDynamicSequenceList(DynamicSequenceList* list) {
+ if (list != NULL) {
+ free(list->data);
+ }
+ list = NULL;
+ return 0;
+}
+
diff --git a/Code/C-Code/source/main.c b/Code/C-Code/source/main.c
new file mode 100644
index 0000000..c784272
--- /dev/null
+++ b/Code/C-Code/source/main.c
@@ -0,0 +1,10 @@
+#include
+#include
+
+
+int main()
+{
+ //SequenceListTest();
+ LinkListTest();
+ return 0;
+}
\ No newline at end of file
diff --git a/Code/C-Code/source/test.c b/Code/C-Code/source/test.c
new file mode 100644
index 0000000..d58f551
--- /dev/null
+++ b/Code/C-Code/source/test.c
@@ -0,0 +1,45 @@
+// ļ
+
+#include "../Head/sequence_list.h"
+#include "../Head/link_list.h"
+
+int SequenceListTest() {
+ DynamicSequenceList list;
+ InitDynamicSequenceList(&list);
+ element_type a[6] = {'1','2','3','4','5','6'};
+ LoopInsertDynamicSequenceList(&list, a, 0, 6);
+ element_type b[3] = { 9, 'a', 'e' };
+ LoopInsertDynamicSequenceList(&list, b, 1, 2);
+ //printf("%d", list.length);
+ PrintfDynamicSequenceList(list);
+ printf("\n");
+ int len = 2;
+ element_type elem[2];
+ MultiDeleteDynamicSequenceList(&list, 0, len, elem);
+ PrintfDynamicSequenceList(list);
+ for (int i = 0; i < len; i++) {
+ printf("%c\n", elem[i]);
+ }
+ /*DynamicSequenceList dlist;
+ InitDynamicSequenceList(&dlist);
+ OtherIncreaseDynamicSequenceList(&dlist, 15);
+ printf("%d", dlist.max_size);*/
+ /*int index = LocateDynamicSequenceListElement(list, '5');
+ printf("%d", index);
+ DestroyDynamicSequenceList(&list);*/
+ return 0;
+}
+
+int LinkListTest() {
+ /*LinkListNode node;
+ InitLinkListWithHead(&node);
+ LinkList list = &node;*/
+ LinkList list = CreateLinkListWithHead();
+ /*int empty = EmptyLinkListWithHead(list);*/
+ /*LinkList list = CreateLinkListWithoutHead();
+ int empty = EmptyLLinkListWithoutHead(list);
+ printf("%d", empty);*/
+ InsertLinkListWithHead(list, 1, '0');
+ return 0;
+}
+
diff --git a/CPP-Code/CMakeLists.txt b/Code/CPP-Code/CMakeLists.txt
similarity index 100%
rename from CPP-Code/CMakeLists.txt
rename to Code/CPP-Code/CMakeLists.txt
diff --git a/CPP-Code/CMakeSettings.json b/Code/CPP-Code/CMakeSettings.json
similarity index 100%
rename from CPP-Code/CMakeSettings.json
rename to Code/CPP-Code/CMakeSettings.json
diff --git a/Code/head.h b/Code/CPP-Code/head/head.h
similarity index 100%
rename from Code/head.h
rename to Code/CPP-Code/head/head.h
diff --git a/CPP-Code/head/link_list.h b/Code/CPP-Code/head/link_list.h
similarity index 100%
rename from CPP-Code/head/link_list.h
rename to Code/CPP-Code/head/link_list.h
diff --git a/CPP-Code/head/sequence_list.h b/Code/CPP-Code/head/sequence_list.h
similarity index 100%
rename from CPP-Code/head/sequence_list.h
rename to Code/CPP-Code/head/sequence_list.h
diff --git a/CPP-Code/source/main.cpp b/Code/CPP-Code/source/main.cpp
similarity index 100%
rename from CPP-Code/source/main.cpp
rename to Code/CPP-Code/source/main.cpp
diff --git a/CPP-Code/source/test.cpp b/Code/CPP-Code/source/test.cpp
similarity index 100%
rename from CPP-Code/source/test.cpp
rename to Code/CPP-Code/source/test.cpp
diff --git a/Code/Code.sln b/Code/Code/Code.sln
similarity index 100%
rename from Code/Code.sln
rename to Code/Code/Code.sln
diff --git a/Code/Code.vcxproj b/Code/Code/Code.vcxproj
similarity index 100%
rename from Code/Code.vcxproj
rename to Code/Code/Code.vcxproj
diff --git a/Code/Code.vcxproj.filters b/Code/Code/Code.vcxproj.filters
similarity index 100%
rename from Code/Code.vcxproj.filters
rename to Code/Code/Code.vcxproj.filters
diff --git a/Code/Code/Code.vcxproj.user b/Code/Code/Code.vcxproj.user
new file mode 100644
index 0000000..88a5509
--- /dev/null
+++ b/Code/Code/Code.vcxproj.user
@@ -0,0 +1,4 @@
+
+
+
+
\ No newline at end of file
diff --git a/Code/double_link_list.h b/Code/Code/double_link_list.h
similarity index 100%
rename from Code/double_link_list.h
rename to Code/Code/double_link_list.h
diff --git a/Code/graph.h b/Code/Code/graph.h
similarity index 100%
rename from Code/graph.h
rename to Code/Code/graph.h
diff --git a/Code/Code/head.h b/Code/Code/head.h
new file mode 100644
index 0000000..3ea11c5
--- /dev/null
+++ b/Code/Code/head.h
@@ -0,0 +1,8 @@
+// ʼ
+#define MAXSIZE 5
+// Ĭֵ
+#define DEFAULTELEM '0'
+// ֵ
+#define INFINITY 32767
+// Ĭ
+typedef char element_type;
diff --git a/Code/link_list.h b/Code/Code/link_list.h
similarity index 100%
rename from Code/link_list.h
rename to Code/Code/link_list.h
diff --git a/Code/link_queue.h b/Code/Code/link_queue.h
similarity index 100%
rename from Code/link_queue.h
rename to Code/Code/link_queue.h
diff --git a/Code/link_stack.h b/Code/Code/link_stack.h
similarity index 100%
rename from Code/link_stack.h
rename to Code/Code/link_stack.h
diff --git a/Code/link_string.h b/Code/Code/link_string.h
similarity index 100%
rename from Code/link_string.h
rename to Code/Code/link_string.h
diff --git a/Code/link_tree.h b/Code/Code/link_tree.h
similarity index 100%
rename from Code/link_tree.h
rename to Code/Code/link_tree.h
diff --git a/Code/main.c b/Code/Code/main.c
similarity index 100%
rename from Code/main.c
rename to Code/Code/main.c
diff --git a/Code/search.h b/Code/Code/search.h
similarity index 100%
rename from Code/search.h
rename to Code/Code/search.h
diff --git a/Code/sequence_list.h b/Code/Code/sequence_list.h
similarity index 100%
rename from Code/sequence_list.h
rename to Code/Code/sequence_list.h
diff --git a/Code/sequence_queue.h b/Code/Code/sequence_queue.h
similarity index 100%
rename from Code/sequence_queue.h
rename to Code/Code/sequence_queue.h
diff --git a/Code/sequence_stack.h b/Code/Code/sequence_stack.h
similarity index 100%
rename from Code/sequence_stack.h
rename to Code/Code/sequence_stack.h
diff --git a/Code/sequence_string.h b/Code/Code/sequence_string.h
similarity index 100%
rename from Code/sequence_string.h
rename to Code/Code/sequence_string.h
diff --git a/Code/sequence_tree.h b/Code/Code/sequence_tree.h
similarity index 100%
rename from Code/sequence_tree.h
rename to Code/Code/sequence_tree.h
diff --git a/Code/sort.h b/Code/Code/sort.h
similarity index 100%
rename from Code/sort.h
rename to Code/Code/sort.h
diff --git a/Code/static_link_list.h b/Code/Code/static_link_list.h
similarity index 100%
rename from Code/static_link_list.h
rename to Code/Code/static_link_list.h
diff --git a/Code/test.c b/Code/Code/test.c
similarity index 100%
rename from Code/test.c
rename to Code/Code/test.c
diff --git a/Code/thread_tree.h b/Code/Code/thread_tree.h
similarity index 100%
rename from Code/thread_tree.h
rename to Code/Code/thread_tree.h
diff --git a/Operate-System/0-summary-ex.md b/Operate-System/0-summary-ex.md
index d7e52aa..18eac54 100644
--- a/Operate-System/0-summary-ex.md
+++ b/Operate-System/0-summary-ex.md
@@ -270,4 +270,24 @@ $D.$仅Ⅱ、Ⅲ、Ⅳ
解:$C$。用户可以在用户态调用操作系统的服务,但执行具体的系统调用服务程序是处于内核态的,Ⅰ正确;设备管理属于操作系统的职能之一,包括对输入/输出设备的分配、初始化、维护等,用户程序需要通过系统调用使用操作系统的设备管理服务,Ⅱ正确;操作系统不同,底层逻辑、实现方式均不相同,为应用程序提供的系统调用接口也不同,Ⅲ错误;系统调用是用户在程序中调用操作系统提供的子功能,Ⅳ正确。
+**例题** 相对于传统操作系统结构,采用微内核结构设计和实现操作系统具有诸多好处,下列()是微内核结构的特点。
+
+Ⅰ.使系统更高效
+
+Ⅱ.添加系统服务时,不必修改内核
+
+Ⅲ.微内核结构没有单一内核稳定
+
+Ⅳ.使系统更可靠
+
+$A.$Ⅰ、Ⅲ、Ⅳ
+
+$B.$Ⅰ、Ⅱ、Ⅳ
+
+$C.$Ⅱ、Ⅳ
+
+$D.$Ⅰ、Ⅳ
+
+解:$C$。微内核结构将操作系统的很多服务移动到内核以外(如文件系统),且服务之间使用进程间通信机制进行信息交换,这种通过进程间通信机制进行的信息交换影响了系统的效率,所以Ⅰ错。由于内核的服务变少,且一般来说内核的服务越少内核越稳定,所以Ⅲ错。而Ⅱ、Ⅳ正是微内核结构的优点。
+
[gantt]:
\ No newline at end of file