C语言:输入一个字符串S1,统计大写字母,小写字母,数字,空格,以及其他字符出现的次数。字符串长度不超过50。 输入格式: 输入S1。 输出格式: 输出占5行,依次为大写字母,小写字母,数字,空格,以及其他字符出现的次数。
时间: 2023-06-09 16:05:21 浏览: 658
ChitGPT: 好的,下面是C语言的程序实现:
```c
#include <stdio.h>
int main()
{
char str[51];
int i, upper=0, lower=0, digit=0, space=0, other=0;
printf("请输入字符串S1:\n");
gets(str);
for(i=0; str[i]!='\0'; i++)
{
if(str[i]>='A' && str[i]<='Z')
upper++;
else if(str[i]>='a' && str[i]<='z')
lower++;
else if(str[i]>='0' && str[i]<='9')
digit++;
else if(str[i]==' ')
space++;
else
other++;
}
printf("大写字母:%d\n", upper);
printf("小写字母:%d\n", lower);
printf("数字:%d\n", digit);
printf("空格:%d\n", space);
printf("其他字符:%d\n", other);
return 0;
}
```
请确认以上程序是否符合您的要求。
相关问题
用c语言编写程序,将字符串 sl(s1 的值为”Jiangsu University of Technology”)中的所有单词按照首字母顺序重新排序后生成一个新的字符串s2并输出;再将s2中的所有小写字母替换为大写字母、所有大写字母替换为小写字母后生成一个新的字符串s3并输出。
在C语言中,我们可以使用以下几个步骤来实现这个功能:
1. **分割字符串**:首先,我们需要把输入的字符串sl按照空格分割成单词数组。这可以使用`strtok()`函数配合字符指针完成。
```c
#include <stdio.h>
#include <string.h>
char *token;
char sl[] = "Jiangsu University of Technology";
char *s2[100]; // 假设最多有100个单词
token = strtok(sl, " "); // 使用空格作为分隔符
while (token) {
s2[count++] = token; // 将单词添加到数组中,并更新计数器
token = strtok(NULL, " ");
}
```
2. **排序单词**:对单词数组进行排序。这里我们假设数组已包含所有单词,可以选择使用`qsort()`或自定义冒泡排序等算法对数组元素进行排序。
```c
// 自己实现快速排序或其他合适的排序算法对s2数组进行排序
void quickSort(char *arr[], int low, int high);
quickSort(s2, 0, count - 1);
```
3. **创建新字符串s2**:将排序后的单词连接起来形成新的字符串s2。由于C语言标准库中没有直接用于连接字符串的函数,可以手动遍历数组并拼接。
4. **转换大小写**:对于s2中的每个字符,使用条件运算符进行大小写的切换。
```c
for (int i = 0; i < strlen(s2[0]); i++) {
if (isupper(s2[0][i])) { // 判断是否为大写字母
s2[0][i] = tolower(s2[0][i]);
} else if (islower(s2[0][i])) { // 判断是否为小写字母
s2[0][i] = toupper(s2[0][i]);
}
}
```
5. **输出结果**:最后输出处理过的字符串s3。
注意:完整的代码实现会涉及到数组长度检查、内存分配释放等问题,此处为了简洁略过了一些细节。下面是伪代码形式的完整过程:
```c
阅读全文