C //习题 8.12 用指针数组处理上一题目,字符串不等长。

C程序设计 (第四版) 谭浩强 习题8.12

习题 8.12 用指针数组处理上一题目,字符串不等长。

IDE工具:VS2010
Note: 使用不同的IDE工具可能有部分差异。

 

代码块
方法1:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void sort(char *s[10], int n);       //定义排序函数

int main(){
	char *str[10], **p;
	for(int i = 0; i < 10; i++){
		str[i] = (char*)malloc(20 * sizeof(char));      //为指针数组分配内存动态空间
		printf("Please enter No.%d string: ", i+1);  //输入10个字符串
		scanf("%s", str[i]);
	}
	sort(str, 10);                                   //调用排序函数
	for(p = str, printf("Sort by: "); p < str + 10; printf("%s ", *p++));    //输出排序后的10个字符串
	printf("\n");

	system("pause");
	return 0;
}

//排序函数
void sort(char *s[10], int n){
	int i, j;
	char *t;
	for(i = 0; i < n; i++){
		for(j = i + 1; j < n; strcmp(s[i], s[j]) > 0 ? t = s[i], s[i] = s[j], s[j] = t, j++ : j++);
	}
}
方法2:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define M 3
#define N 80

void initialStr(char ***str, int m, int n){
	*str = (char**)malloc(m * sizeof(char*));
	for(int i = 0; i < m; i++){
		(*str)[i] = (char*)malloc(n * sizeof(char));
	}
}

void inputStr(char **str, int m){
	printf("Enter %d strings:\n", m);
	for(int i = 0; i < m; i++){
		printf("Enter No.%d strings: ", i + 1);
		gets(str[i]);
	}
}

void sortStr(char **str, int m, int n){
	char *temp = (char*)malloc(n * sizeof(char));
	for(char **p = str; p < str + m; p++){
		for(char **q = p + 1; q < str + m; q++){
			if(strcmp(*p, *q) > 0){
				strcpy(temp, *p);
				strcpy(*p, *q);
				strcpy(*q, temp);
			}
		}
	}
	free(temp);
}

void outputStr(char **str, int m){
	printf("\nNew sort:\n");
	for(int i = 0; i < m; i++){
		printf("%s\n", str[i]);
	}
}

void freeStr(char ***str, int m){
	for(int i = 0; i < m; i++){
		free((*str)[i]);
	}
	free(*str);
}

int main(){
	char **str = NULL;

	initialStr(&str, M, N);
	inputStr(str, M);
	sortStr(str, M, N);
	outputStr(str, M);
	freeStr(&str, M);
	
	system("pause");
	return 0;
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Navigator_Z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值