[英]Sorting an array of strings in c using pointers
所以我想對一個字符串數組進行排序,但我不知道如何將它傳遞給函數。另外,這個代碼的等價物是什么,但使用指針?
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void sort(int *s)
{
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++)
if(strcmp(s[i],s[j])>0)
{
char aux[100];
strcpy(aux,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],s[i]);
}
}
int main()
{
char s[3][100];
for(int i=0;i<3;i++)
scanf("%s",s[i]);
sort(s);
return 0;
}
void sort(int *s)
{
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++)
if(strcmp(s + i,s+j)>0)
{
char aux[100];
strcpy(aux,s+i);
strcpy(s+i,s+j);
strcpy(s+i,aux);
}
}
int main()
{
char s[3][100];
for(int i=0;i<3;i++)
scanf("%s",s+i);
sort(s);
return 0;
}
無論如何,您的程序中有一個錯誤:
strcpy(aux,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],s[i]);
應該:
strcpy(aux,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],aux);
以下代碼段修復了sort
函數中的錯誤並使用指針:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void sort(char ** s, unsigned int size) {
for(unsigned int i=0 ; i<size ; i++) {
for(unsigned int j=i+1 ; j<size ; j++) {
if(strcmp(s[i],s[j])>0) {
char aux[100];
strcpy(aux,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],aux);
}
}
}
}
int main() {
unsigned int string_number = 3;
unsigned int string_max_size = 100;
char ** s = (char **) malloc(string_number*sizeof(char*));
for(unsigned int i=0 ; i<string_number ; i++) {
s[i] = (char*) malloc(string_max_size*sizeof(char));
scanf("%s", s[i]);
}
sort(s, string_number);
for(unsigned int i=0 ; i<string_number ; i++) {
for(unsigned int i=0 ; i<string_number ; i++) {
printf("%s\n", s[i]);
free(s[i]);
}
free(s);
return 0;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.