算法竞赛入门经典 5.1.1 WERTYU 5.1.2 Tex括号

5.1.1  WERTYU 

 把手放在键盘上时,稍不注意就会往右错一位。 这样的话,Q会变成W,J会变成K等。 输入一个错位敲出的字符串,输出打字员本来想打出的句子。

 样例输入:O S,GOMR YPFSU/

 样例输出:I AMFINE TODAY. 


#include <stdio.h>
#include <stdlib.h>
char *s = "`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./"; 

int main(int argc, char *argv[])
{
  int i, c;
  while((c = getchar()) != EOF)
  {
     for(i = 1; s[i]&&s[i]!=c; i++);
     if(s[i]) putchar(s[i-1]);
     else putchar(c);
  
  }
  system("PAUSE");	
  return 0;
}

总结:1 反义字符的表示  \\

            2 int c = getchar()

            3 s[i]&&s[i] != c   存在找不到的情况,考虑周全,循坏结束后下一步要判断从哪点退出循坏的


5.1.2 

 TeX括号  在TeX中,左双引号``,右双引号"。输入一篇篇包含双引号的文章,你的任务是把它转换成TeX的格式。

  样例输入:"To be or not to be,"quoth the Bard, "that is the question". 

  样例输出:``To be or not to be,"quoth the Bard, ``that is the question''.

#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
  int c, q = 1;
  while((c = getchar()) != EOF)
  {
  if(c == '"') {printf("%s", q ? "``" : "''"); q = !q;}
  else putchar(c);         
  }
  system("PAUSE");	
  return 0;
}

总结:1 c == '"'

            2 用q来判断是单次遇到还是双次遇到

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值