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