本文目錄一覽:
- 1、C語言中,有一個指向指針數組的指針,我想要問要怎麼交換兩個指針的值來做到,將指針數組裡的指針排序。
- 2、c語言中怎麼用指針調換順序
- 3、C語言用指針法交換兩個數的順序問題
- 4、是C語言,我要具體的動態鏈表的排序方法,是交換結構體里的指針,
C語言中,有一個指向指針數組的指針,我想要問要怎麼交換兩個指針的值來做到,將指針數組裡的指針排序。
int *arry[10]; //指針數組 int (*arryp)[10]; //數組指針,因為數組指針指向數組,而數組也可看做是個指針,那數組指針可以理解為一個二 級指針 int a[10]; arryp = a; //將數組地址個數組指針 arry[0] = *arryp; //arry[0]是一級指針,要將數組指針賦給指針數組,就要取內容,實際就是 arry[0] = a;
c語言中怎麼用指針調換順序
要調換三個數的順序,用排列組合原理簡單的計算總共有6種方法,不知道樓主是想按其中某種方法交換變量的具體數值,還是將所有6種排序都打印出來?
例如,a=1,b=2,c=3,交換後結果為:a=3,b=1,c=2.
首先需要兩個中間變量作為交換的媒介。程序如下
:
main()
{
int
a=1,b=2,c=3;
int
*x=a,*y=b,*z=c;/*定義3個指針變量,並分別賦予初值為a,b,c的地址。*/
int
*p=null,*s=null;/*x為交換中介指針變量,初始化為空*/
*p=*x;
*s=*y;
*x=*z;
*y=*p;
*z=*s;
printf(“%d
%d
%d”,a,b,c);
getch();
}
其實交換數不需要用到指針,直接運用變量本身也可交換。當然指針交換的好處在於函數內部可以實際交換兩個數的值。
C語言用指針法交換兩個數的順序問題
解答:
1. 注意形式參數和實際參數的區別,主函數中的x,y是實際參數,swap函數中的a,b是形式參數。他們各有自己的存儲空間,互不干擾。
2. 在程序適當位置加上輸出地址的語句,即可看出為什麼回到主程序後,x,y的值為什麼不交換。
為了更形象,可以用圖表示它們的關係:
可見,交換的只是swap函數中的a,b值,對主函數中的a,b值沒有影響。
3. 修改的方法,將swap的交換變成值的交換。
是C語言,我要具體的動態鏈表的排序方法,是交換結構體里的指針,
可以試試這段代碼
#includestdio.h
#includemalloc.h
typedef struct node
{
int data;/*data代表成績分數*/
struct node *next;
}LNode,*LinkList;
LinkList Creat(void)/*創建鏈表,結束標誌為當輸入的數據為0!*/
{
LinkList H,p1,p2;
int n;
n=0;
p1=p2=(LinkList)malloc(sizeof(LNode));
printf(“輸入數據:”);
scanf(“%d”,p1-data);
H=NULL;
while(p1-data!=0)
{
n=n+1;
if(n==1)
H=p1;
else
p2-next=p1;
p2=p1;
p1=(LinkList)malloc(sizeof(LNode));
scanf(“%d”,p1-data);
}
p2-next=NULL;
return(H);
}
LinkList Sort(LinkList SL)/*遞增排序函數:入口參數:鏈表的頭指針,此為鏈表中的排序函數*/
{
LinkList p,q;
int temp;
for(p=SL;p!=NULL;p=p-next)
{
for(q=p-next;q!=NULL;q=q-next)
{
if(p-dataq-data)
{
temp=q-data;
q-data=p-data;
p-data=temp;
}
}
}
return SL;
}
int main()
{
LinkList L,S,K;
L=Creat();
printf(“初始化的單鏈表數據序列為:\n”);
for(S=L;S!=NULL;S=S-next)
printf(“%d “,S-data);
Sort(L);
printf(“\n按遞增順序排序後的序列為:\n”);
for(K=L;K!=NULL;K=K-next)
printf(“%d==”,K-data);
return 0;
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/187755.html