九度OJ 1121:首字母大写 (字符串处理)

本文介绍了一种将字符串中每个单词的首字母转换为大写的算法实现,该算法使用C语言编写,能够处理包含多种空白符分隔的单词。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

时间限制:1 秒

内存限制:32 兆

特殊判题:否

提交:2865

解决:1007

题目描述:

对一个字符串中的所有单词,如果单词的首字母不是大写字母,则把单词的首字母变成大写字母。
在字符串中,单词之间通过空白符分隔,空白符包括:空格(' ')、制表符('\t')、回车符('\r')、换行符('\n')。

输入:

输入一行:待处理的字符串(长度小于100)。

输出:

可能有多组测试数据,对于每组数据,
输出一行:转换后的字符串。

样例输入:
if so, you already have a google account. you can sign in on the right.
样例输出:
If So, You Already Have A Google Account. You Can Sign In On The Right.
来源:
2008年北京大学图形实验室计算机研究生机试真题

代码:

#include <stdio.h>
#include <string.h>
 
void toUpper(char *c)
{
    if (*c >= 'a' && *c <= 'z')
        *c += 'A' - 'a';
}
 
int main(void)
{
    char s[100];
 
    //while (scanf("%[^\n]", s) != EOF)
    while (gets(s))
    {
        for (int i=0; i<strlen(s); i++)
        {
            if (i == 0)
                toUpper(&s[i]);
            else if (s[i-1] == ' ' || s[i-1] == '\t' || s[i-1] == '\r')
                toUpper(&s[i]);
        }
        printf("%s\n", s);
    }
 
    return 0;
}
/**************************************************************
    Problem: 1121
    User: liangrx06
    Language: C
    Result: Accepted
    Time:0 ms
    Memory:912 kb
****************************************************************/


转载于:https://www.cnblogs.com/liangrx06/p/5083911.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值