c語言數(shù)組怎么用 c語言用指針給數(shù)組排序和插入?
c語言用指針給數(shù)組排序和插入?#包括和限制。H>#define size 8//element array int main(){int i,nums[size]={13,27,38,49,65,
c語言用指針給數(shù)組排序和插入?
#包括和限制。H>#define size 8//element array int main(){int i,nums[size]={13,27,38,49,65,76,97},N,index,*P=&nums[size-1]printf(“original array:”)for(i=0I<size-1i)printf(%d”,nums[i])printf(“”N輸入要插入的數(shù)字:”)scanf(%d”,&n)printf(“input要插入的數(shù)字后面:”)scanf(%d”,&index)while(P>&nums[index]){*P=*(P-1)P--}*P=n printf(”inserted array:”)for(I=0I<sizei)printf(%d”,nums[I])return 0}
宏定義數(shù)組不能動態(tài)增加其長度。只能通過修改宏來重新編譯它。例如,由#define n 100int a[n],B[n],C[n]定義的ABC是100個元素。如果您修改#define n 1000,它是所有1000個元素。
C語言實現(xiàn)宏定義數(shù)組增加長度,不用指針?
簡而言之,指針是表示地址的無符號整數(shù)。
所以僅僅理解指針是不夠的。您還需要知道指針指向的數(shù)據(jù)空間是如何排列的。這可能涉及到一些與特定CPU/OS相關(guān)的知識。如果我們能用計算機(jī)體系結(jié)構(gòu)的知識來理解它,它會更深刻、更準(zhǔn)確。
例如:
如何存儲float/double/long double?
如何在數(shù)據(jù)空間中組織陣列?
字符串是如何存儲的?
如何存儲結(jié)構(gòu)和聯(lián)合體?
位域組織
具體CPU相關(guān)部分如下:
整數(shù)的存儲將涉及CPU大小的指定
浮點數(shù)的存儲直接關(guān)系到FPU的設(shè)計
此外,還有一些擴(kuò)展知識,涉及內(nèi)存的分配和釋放:如何在程序中分配內(nèi)存?(malloc/free)
什么是堆和堆棧?
總而言之:指針是地址和整數(shù)。但要充分利用它,我們需要了解計算機(jī)存儲空間的分配。困難在這里,突破在這里。