标签:没有 字符 问题 选择 style switch ase lse lan
T
),或者放置一块奶酪(C
),或者什么也不放(X
)。捕鼠夹可重复利用,不计成本,奶酪每块3元。X
),老鼠们就不高兴了(Unhappy),会有长达一天(也就是第二天)的不高兴期。在不高兴期间,不派出老鼠。不高兴期结束之后,派出老鼠。T
),这只老鼠被引诱吃掉奶酪并被打死(Dead),老鼠们会有长达两天(也就是第二和第三天)的伤心期。在伤心期间,不派出老鼠。伤心期结束之后,派出老鼠。在这种情况下,抓到1只老鼠可获得奖励10元,但同时也耗费了一块奶酪。注意,如果某一天放置了捕鼠夹但老鼠没有出现,则没有耗费奶酪。C
),老鼠吃了奶酪会很开心(Happy!),会有长达两天(第二和第三天)的兴奋期。在兴奋期间,即使叠加了不高兴或者伤心,也必定派出老鼠。在这种情况下,没抓到老鼠,而且耗费了一块奶酪。注意,如果某一天放置了奶酪但老鼠没有出现,则奶酪可以下次再用,没有耗费。输入格式:
输入在一行中给出连续的由C
或T
或X
组成的不超过70个字符的字符串,以$
结束。字符串中每个字符表示这一天的操作( 即X
:什么都不放;T
:放捕鼠夹;C
:放奶酪)。题目保证至少有一天的操作输入。
输出格式:
要求在第一行输出连续的字符串,与输入相对应,给出老鼠的状态:!
表示派出老鼠吃到奶酪D
表示派出老鼠被打死U
表示派出老鼠无所获-
表示没有派出老鼠输入样例1:
TXXXXC$
输出样例1:
D--U-!
4
输入样例2:
CTTCCX$
输出样例2:
!DD--U
11
#include<stdio.h> int main() { char a; int i,b=0; int e,f; int c=1,d=0,g=0; for (i=1;;i++) { a=getchar(); if(a==‘$‘) break; if(c==1) switch(a) { case ‘X‘: {e=1;printf("U");break; } case ‘T‘: {f=2;d++;g++;printf("D");break; } case ‘C‘: {b=2;d++;printf("!");break; } } else printf("-"); if(b>0) {b--;c=1;e=0;f==0;} else if(b<=0&&e==1) {c=0;e--;} else if(b<=0&&f>0) {c=0;f--;} else c=1; } printf("\n%d",g*10-d*3); }
这道题目太难了,我只知道要用到switch以及最后算盈利的公式,实在是不会做。
标签:没有 字符 问题 选择 style switch ase lse lan
原文地址:https://www.cnblogs.com/twk0909/p/10407591.html