#include "stdafx.h" #include "stdio.h" void out_student(char (*p)[20],int n); char (*p)[20]Data pointer (row pointer) tühi sort_student(märk (*p)[20],int n); int main() {tegelase õpilased[3][20]; int i; for(i=0; i<3; i++) scanf("%s",*(õpilas+i)); Sisenemine out_student(õpilased,3); sort_student(õpilased,3); out_student(õpilased,3); tagasitulek 0;
} void out_student(char (*p)[20],int n) //(*p) rea aadress {int i; for(i=0; i<n; i++) printf("%s",*(p+i)); printf("\n");
}
//选择排序 void sort_student(tähe (*p)[20],int n) {int i,j; for(i=0; i<n-1; i++) {int pos=i; for(j=i+1; j<n; j++) {if(strcmp(*(p+j),*(p+pos)<0)) //strcmp(*(p+j),*(p+pos)<0) *(p+j) ei saa olla reaaadress, see peab olema veeru aadress, esimese järgu massiivi esimene aadress {pos=j; }
}
} if(pos!=i) {char str[20]={'\0'}; strcpy(str,*(p+pos)); *(p+pos) Pos-rea esimese veeru aadress, swap-string strcpy(*(p+pos),*(p+i)); strcpy(*(p+i),str);
}
}
//总结:
/*二维数组表示(行地址,列地址) Osutaja liigub massiivi läbi 2D märgimassiivi (rea aadress, veeru aadress) */
|