我需要制作可以插入一行单词的程序,并且程序将使所有单词都像第一个单词(大写小写)。
示例:
插入行 - AbbA 名人堂类
并且程序的输出应该是: - AbbA HallL FamEee ClaSs
我怎样才能检查完整的单词,并找出有什么符号 - 大写还是小写?然后用相同的方案制作所有单词。
[注释] 创建一个布尔数组,并捕获第一个单词的每个字符的大写/小写信息。使用相同的布尔数组,格式化剩余的单词。这就是我现在能帮你的全部了。您可以尝试编写程序并返回论坛,以便获得更多响应。由于我无权发表评论,因此我在答案部分添加我的评论
[回答] 给你...
#include <stdio.h>
#include <string.h>
int main() {
char inputStr[] = "AbbA hall fameee class";
char bool_arr[50];
char *ptr;
int len = 0;
int loopcnt = 0;
int i = 0;
printf("Input Str: %s\n", inputStr);
ptr = strtok(inputStr, " ");
len = strlen(ptr);
for(i = 0; i < len; i++) {
if(toupper(ptr[i]) != ptr[i]) {
bool_arr[i] = 0; //Lower case
}
else {
bool_arr[i] = 1; //Upper case
}
}
while(ptr != NULL) {
if(strlen(ptr) < len) {
loopcnt = strlen(ptr);
}
else {
loopcnt = len;
}
for(i = 0; i < loopcnt; i++) {
if(bool_arr[i] == 0 &&
(tolower(ptr[i]) != ptr[i])) {
ptr[i] = tolower(ptr[i]);
}
if(bool_arr[i] == 1 &&
(toupper(ptr[i]) != ptr[i])) {
ptr[i] = toupper(ptr[i]);
}
}
printf("%s ", ptr);
ptr = strtok(NULL, " ");
}
}
char str[]=" AbbA hall fameee class";
int flag=0;
int i;
for(i=0;i<len(str);i++)
{
if(flag==0 && str[i]==' ')
{
str[i+1]+=32;
flag=1;
}
else
{
flag=0;
}
}