【白书之路】10082 - WERTYU string使用
来源:互联网 发布:淘宝男模特招聘条件 编辑:程序博客网 时间:2024/06/01 07:19
10082WERTYU
Acommontypingerroristoplacethehandson thekeyboardonerowtotherightofthecorrect position. So ‘Q’ is typed as ‘W’ and ‘J’ is typed as ‘K’ and so on. You are to decode a message typed in this manner.
Input
Input consists of several lines of text. Each line may contain digits, spaces, upper case letters (except Q, A, Z), or punctuation shown above [except back-quote (`)]. Keys labelled with words [Tab, BackSp, Control, etc.] are not represented in the input.
Output
You are to replace each letter or punction symbol by the one immediately to its left on the ‘QWERTY’ keyboard shown above. Spaces in the input should be echoed in the output.
Sample Input
O S, GOMR YPFSU/
Sample Output
I AM FINE TODAY.
有关字符串的题目,这种题目可以在时间复杂度允许的情况下使用库函数或者stl,这里我是用了string,有一点需要注意:字符串中的反斜杠,这很可能成为错误点。还有尽量不要使用gets,这个函数在比较新的版本中已经被取消了,因为没有对缓冲区溢出进行处理,可以使用fgets(),三个参数,第一个是缓冲区指针,第二个读取的字符数量,第三个是文件流指针,我们可以使用标准流stdin来实现从键盘读入。string的find函数返回所找字符(串)在目标串的起始位置,如果没找到则返回string::npos,使用size_t来接收返回值。
#include <iostream>#include <stdio.h>#include <string.h>using namespace std;string dic="`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./";char str[1000];int main(){ int i; size_t pos; while(fgets(str,1000,stdin)!=NULL) { for(i=0;i<strlen(str);i++) { pos=dic.find(str[i]); //printf("pos=%d\n",pos); if(pos!=-1) str[i]=dic[pos-1]; } printf("%s",str); } return 0;}
- 【白书之路】10082 - WERTYU string使用
- 白书练习 WERTYU
- 10082 - WERTYU
- 10082WERTYU
- UVa - 10082 - WERTYU (常量数组的使用)
- UVa Problem 10082 WERTYU (WERTYU 键盘)
- uva-10082 - WERTYU
- UVa 10082 WERTYU
- UVa OJ 10082-WERTYU
- uva 10082 - WERTYU
- UVa 10082 - WERTYU
- UVA 10082 - WERTYU
- uva 10082 - WERTYU
- UVa 10082 WERTYU
- UVA 10082 WERTYU
- UVA-10082 WERTYU
- UVA 10082 - WERTYU
- UVA-10082 WERTYU
- 微信公众账号登陆授权开发——5(解决使用官方获获取第三方平台方获取预授权码)
- MyEclipse 中各种 libraries 的含义
- 如何编写一个没有主函数的C程序
- 1101 -- 正弦和余弦
- Java中的main()方法详解
- 【白书之路】10082 - WERTYU string使用
- 1102 -- 两点距离
- git常用命令
- Win8 分区教程
- java定时任务管理实现-quartz
- 1103 -- 偶数
- 1104 -- 打折
- 图理解单链表的反转
- C++ 最长子数组问题求解——分治法(递归)