用C语言完成这个任务 本题实现,输入一个包含空格的多单词字符串,单词与单词之间用1个或多个空格分隔。请将字符串中用空格分隔的单词排序后在屏幕上输出来。 要求用指针完成函数中各参数的传递与访问,自定义函数头和函数体中不得出现数组下标形式的表示法。 函数接口定义: int split_sort(char *str,char **pStr);函数对字符串中的单词进行分割,并按字典顺序输出排序后的单词,函数返回字符串中单词的数目。str用于接收实参字符串,pStr用于存放分割后的各单词对应字符串的首地址。下面函数的定义部分框架与花括号部分已经给出了,只需给出函数{...}之中的部分。
时间: 2023-06-12 10:03:59 浏览: 157
```
#include<stdio.h>
#include<string.h>
int split_sort(char *str,char **pStr){
int i,j,k,n=0,len=strlen(str);
char *p;
for(i=0;i<len;i++){
if(str[i]!=' '){
j=i;
while(str[i]!=' '&&i<len) i++;
pStr[n]=(char*)malloc(i-j+1);
strncpy(pStr[n],str+j,i-j);
pStr[n][i-j]='\0';
n++;
}
}
for(i=0;i<n-1;i++){
k=i;
for(j=i+1;j<n;j++){
if(strcmp(pStr[j],pStr[k])<0) k=j;
}
if(k!=i){
p=pStr[i];
pStr[i]=pStr[k];
pStr[k]=p;
}
}
for(i=0;i<n;i++){
printf("%s ",pStr[i]);
}
return n;
}
```
相关问题
用c语言写1)输入一行字符串,计算该行字符中包含多少个单词,单词之间用空格分隔开。
在C语言中,你可以通过以下几个步骤实现这个功能:
1. 定义一个函数,例如`count_words(char *str)`,它接受一个指向字符串的指针作为参数。
2. 初始化一个计数器(通常是整型变量),用于存储单词的数量,初始值设为0。
3. 遍历字符串,遇到空格就读取下一个单词。在遍历过程中,需要跳过开头和结尾的空格。
4. 使用`while`循环和条件判断,当读到非空格字符时,表示当前正处理一个单词。每遇到空格,将计数器加一,然后继续查找下一个单词。
5. 当遍历完整个字符串后,如果末尾还有字符(即不是空格),说明最后一个单词未结束,也需要加一次计数器。
6. 返回计数器作为结果。
以下是简单的示例代码:
```c
#include <stdio.h>
#include <ctype.h> // 用于检查是否为空格
int count_words(char *str) {
int word_count = 0;
char* current_word = str; // 指向当前处理的单词位置
while (*current_word != '\0') { // 遍历字符串直到遇到'\0'
if (isspace(*current_word)) { // 如果遇到空格
++word_count; // 统计一个单词
current_word++; // 移动到下一个非空格字符
} else {
current_word++; // 直接移动到下一个字符,非空格则继续当前单词
}
}
// 判断是否遗漏了最后一个单词
if (!isspace(current_word[-1])) {
++word_count;
}
return word_count;
}
int main() {
char input[100];
printf("请输入一行字符串: ");
fgets(input, sizeof(input), stdin); // 从标准输入获取字符串
input[strcspn(input, "\n")] = '\0'; // 去除换行符
int word_count = count_words(input);
printf("字符串中有 %d 个单词。\n", word_count);
return 0;
}
```
用c语言编写:输入一行字符,统计其中包括多少单词,单词之间用一个或多个空格分隔
在C语言中,我们可以使用标准库函数来统计输入的一行字符中包含的单词数。下面是一个简单的示例程序,它首先读取一行输入,然后分割成单词并计算单词的数量:
```c
#include <stdio.h>
#include <ctype.h> // 包含用于处理字符类型的头文件
int count_words(char str[]) {
int word_count = 0;
int start_word = 0; // 用于跟踪当前单词的开始位置
for (int i = 0; str[i] != '\0'; i++) { // 遍历字符串直到遇到结束符
if (isspace(str[i])) { // 如果字符是空格
if (i > start_word) { // 如果这之前有非空格字符,则计数加一
word_count++;
}
start_word = i + 1; // 更新起始位置到下一个单词
} else { // 非空格字符
start_word = i; // 如果遇到非空格,更新起始位置
}
}
// 别忘了检查最后一个单词
if (str[i] == '\0' && i > start_word) {
word_count++; // 如果字符串结尾是空格后的单词,也计入
}
return word_count;
}
int main() {
char input[100]; // 定义足够大的数组来存储一行字符
printf("请输入一行字符(以空格分隔单词): ");
fgets(input, sizeof(input), stdin); // 从标准输入获取一行字符
input[strcspn(input, "\n")] = '\0'; // 移除换行符
int word_count = count_words(input);
printf("输入的字符串中有 %d 个单词。\n", word_count);
return 0;
}
```
阅读全文