一道C语言题的两种解法(C Peimer Plus)

目录:

  1. 题目大纲
  2. 解法一
  3. 解法二

题目大纲

        编写一个符合一下描述的函数。首先,询问用户需要输入多少个单词。然后,接受用户输入的单词,并显示出来。使用malloc()并回答第一个问题(即要输入多少个单词),创建一个动态数组,该数组包含指向char的指针(注意,因为数组的每个元素都是指向char的指针,所以用于存储malloc()返回值的指针应该是一个指向指针的指针,且它所指向的指针指向char)。在读取字符串时,该程序应该把单词读入一个临时的char数组,使用malloc()分配足够的内存空间来存储单词,并把地址存入该指针数组(该数组中的每个元素都是指向char的指针)。然后,从临时数组中吧单词复制到动态分配的存储空间中。因此,有一个字符指针数值,每个指针都指向一个对象,该对象的大小正好能容纳要存储的特定单词。下面是该程序的一个运行示例:

How many words do you wish to enter? 5
Enter 5 words now: I enjoyed doing this exercise
Here are your words:
I
enjoyed
doing
exercise

解法一

        代码如下;

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

int main()
{
    int amount;
    printf("How many words do you wish to enter?");
    scanf("%d",&amount);
    printf("Enter %d words now: ",amount);
    char **pst = (char ** )malloc(amount * sizeof(char *));
    /*
	因为数组的每个元素都是指向char的指针,所以用于存储malloc() 
	返回值的指针应该是一个指向指针的指针,且它所指向的指针指向char 
	*/
    
    for(int i = 0;i < amount; i++)
	{
		char temp[100];
		scanf("%s",temp);
		
		int length = strlen(temp);
		char* str = (char*)malloc(length * sizeof(char));
		//获取用户输入的字符串长度,并创建一个长度匹配的字符串
		
		strcpy(str,temp);
		
		*(pst + i) = str;
		//将字符串指针指向新创建的字符串
	} 	
	for(int i = 0; i < amount; i++ )
	{
		printf("%s\n",*(pst + i));
	}
	free(pst);
	printf("\nAll Done!\n");
	return 0;





}

本解法运用灵活运用指针,不足的是temp数组的长度是定值,容易出现bug(当然,应该没人用超过100个字母的单词吧~)

解法二

        代码如下:

#include<stdio.h>
#include<stdlib.h>


void copy(char *p1,char *p2,int n);




int main()
{
	int words_num;//用户准备输入单词的数量
	char ch;
	
	printf("How many words do you wish to enter?") ;
	
	scanf("%d", &words_num);
	getchar();
	
	char * p[words_num];// 定义指针数组 
	
	printf("Enter %d words now:",words_num);
	
	for(int i = 0;i<words_num;i++)
	{
		int words_count = 0;
		char * a;
		char * b;
		
		while((ch = getchar())!=' '&&ch !='\n')
		{
			
			words_count++;
			free(a);
			a = malloc((words_count+1)*sizeof(char));
			copy(a,b,words_count);
			free(b);
			b = malloc(words_count*sizeof(char));
			a[words_count-1] = ch;
			copy(b,a,words_count);
		}
		/*
			这里的处理比较复杂,本解法解决了第一种解法中无法输入超过100个字母单词的问题
			思路是这样的:
				首先,先是创建俩个指向char的指针,在while循环中每一次的循环都会得到一个字符
			,words_counts变量记录字母数量。先是通过free释放a的内存,然后a复制b数组中的数据 
			,然后,b数组释放内存。将得到的字符存入a数组中,为b数组分配内存,b复制a中的数据。
			然后再一次开始循环。。。。。。。。直到读到SPACE或者是换行符。 
				*/
	
		p[i] = (char*)malloc((words_count+1)*sizeof(char));
		
		copy(p[i],b,words_count);
		
		
		
		p[i][words_count] = '\0';
		words_count = 0;
		
		free(a);
		free(b);
		
		
	}
	
	printf("Here are you words:\n"); 
	for(int i = 0;i<words_num;i++)
		printf("%s\n",p[i]);

	
	printf("\nAll Done!\n");
	return 0;
}




void copy(char *p1,char *p2,int n)
{
	for(int k = 0;k<n;k++)
	{
		p1[k] = p2[k];
	}
}

本人水平有限,欢迎大佬们在评论区指出错误的地方

Thanks♪(・ω・)ノ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值