当前位置:   article > 正文

题8.12:用指针数组处理上一函数,字符串不等长。在主函数中输入10个等长的字符串。用另一函数对它们排序_在主函数中输入10个等长的字符串,用另一函数按照指针

在主函数中输入10个等长的字符串,用另一函数按照指针

题目

本题是谭浩强《C程序设计课后习题》题8.12。
题目:
8.:11:在主函数中输入10个等长的字符串。用另一函数对它们排序。然后在主函数输
出这10个已排好序的字符串。
8.12:用指针数组处理上一函数,字符串不等长


以下是本篇文章正文内容,欢迎朋友们进行指正,一起探讨,共同进步。——来自考研路上的lwj

一、解题思路

思路:
1.使用strcmp字符串比较函数进行比较。
2,本题使用冒泡排序的两种情况:从小到大排序和从大到小排序,均以通过编译运行正确,数据交换部分没有使用strcpy,使用了题目要求的指针数组进行数据的交换。

二、代码部分

1.引入库

代码如下(示例):

#include<stdio.h> 
#include<string.h>
  • 1
  • 2

2.主函数部分

代码如下(示例):

int i, j;
void strsort2(char* pstr[], int n)//冒泡排序从小到大,使用指针数组。
{
	for(i=0;i<n-1;i++)
		for(j=0;j<n-1-i;j++)
			if (strcmp(*(pstr + j), *(pstr + j + 1)) > 0)
			{
				char *tmp= *(pstr + j);
				*(pstr + j)= *(pstr + j + 1);
				*(pstr + j + 1)=tmp;
			}
}
void strsort(char* pstr[], int n)//冒泡排序从大到小,使用指针数组。
{
	for(i=0;i<n;i++)
		for(j=i+1;j<n;j++)
			if (strcmp(*(pstr + i), *(pstr + j)) < 0)
			{
				char* tmp = *(pstr + i);
				*(pstr + i) = *(pstr + j);
				*(pstr +j) = tmp;
			}
}
int main()
{
	char str1[32][32] = {0};
	char* pstr[32];//定义指针数组
	for (i = 0; i < 32; i++)
		pstr[i] = str1[i];//定义了32个指针指向str1中的各个元素
	printf("请输入字符串的个数:");
	int n;
	scanf("%d", &n);
	printf("请输入%d个字符串:\n", n);
	for (i = 0; i < n; i++)
		scanf("%s", pstr[i]);
	strsort2(pstr, n);//传参过去的是指向数组的指针数组pstr
	for (i = 0; i < n; i++)
		printf("%s\n", pstr[i]);
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40

三、执行结果

在这里插入图片描述

输出:

请输入字符串的个数:5
请输入5个字符串:
我爱
我爱C
我爱C语言
我是李文杰
我一定会考上中国海洋大学
我爱
我爱C
我爱C语言
我是李文杰
我一定会考上中国海洋大学
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/293003
推荐阅读
相关标签
  

闽ICP备14008679号