九度OJ 1121:首字母大写 (字符串处理)
2015-10-23 23:03
246 查看
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:2865
解决:1007
题目描述:
对一个字符串中的所有单词,如果单词的首字母不是大写字母,则把单词的首字母变成大写字母。
在字符串中,单词之间通过空白符分隔,空白符包括:空格(' ')、制表符('\t')、回车符('\r')、换行符('\n')。
输入:
输入一行:待处理的字符串(长度小于100)。
输出:
可能有多组测试数据,对于每组数据,
输出一行:转换后的字符串。
样例输入:
样例输出:
来源:2008年北京大学图形实验室计算机研究生机试真题
代码:
内存限制: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 ****************************************************************/
相关文章推荐
- nfc读卡在android 4.4以上与4.4以下写法的区别
- 聊聊内聚性
- 九度OJ 1121:首字母大写 (字符串处理)
- Tomcat的目录结构,虚拟主机配置
- 九度OJ 1120:全排列 (DFS)
- 九度OJ 1120:全排列 (DFS)
- 洛谷P1024/NOI题库7891(2.3)/NOIP2001提高组T1 一元三次方程求解
- 如何调整seekbar的高度
- linux系统常用命令和解析
- Xms Xmx PermSize MaxPermSize 区别
- cpp项目的组织
- 你所不知道的事儿--C++中delete指针后最好赋值为NULL
- sizeof
- 你所不知道的事儿--C++中delete指针后最好赋值为NULL
- MSF终端命令
- LiteHttp 第一节:初始化和初步使用
- 九度OJ 1119:Integer Inquiry(整数相加) (大数运算)
- Javascript计数器
- 九度OJ 1119:Integer Inquiry(整数相加) (大数运算)
- 【翻译】Ext JS最新技巧――2015-10-21