我需要制作程序,我可以在其中插入带有单词的行,程序将使所有单词成为第一个单词(大写小写)。
例:
插入行 - AbbA hall fameee class
并且程序的输出应该是: - AbbA HalL FamEee ClaSs
如何检查完整的单词,并找出有哪些符号 - 上部或下部?然后用相同的方案制作所有单词。
答案 0 :(得分:3)
[注释] 创建一个布尔数组并捕获第一个单词的每个字符的大写/小写信息。使用相同的布尔数组,格式化剩余的单词。这就是我现在可以帮助你的一切。您可以尝试编写程序并返回论坛,以便获得更多响应。由于我没有权利发表评论,我在答案部分添加我的评论
[答案] 你去......
#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, " ");
}
}
答案 1 :(得分:0)
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;
}
}