一个牛皮的模拟(真牛皮)

最近在写洛谷的训练场,看到一个交叉模拟的题目。冥思苦想,写了百多行的代码,实在绕不清,然后我看题解,居然只有24行,必须要发篇博客。
洛谷P1098

题目描述

在这里插入图片描述

输入格式

在这里插入图片描述

输出格式

在这里插入图片描述

题目大意

给你三个参数p1,p2,p3以及一个字符串,其中字符串中含有减号,若满足条件则根据参数改变字符串。
这个题一看,就是很恶心的模拟,你一步一步来,代码量很大,但思路并不难,细节难以处理。然后现在就是我看到这个牛皮的代码了。

#include<bits/stdc++.h>
using namespace std;
int p1,p2,p3,i=0,k;
char ch[300],be,af,f,j,p;//p用于输出; 
int main() {
    scanf("%d%d%d%s",&p1,&p2,&p3,ch);//输入;
    while(ch[i]){//当ch[i]有值时;
        be=ch[i-1];af=ch[i+1];f=ch[i];//f存储ch[i],便于判断; 
        if(f=='-'&&af>be&&(be>='0'&&af<='9'||be>='a'&&af<='z')){//意思是ch[i]若为'-',就判断其前后是否满足条件,满足进入循环; 
            for(p3==1?j=be+1:j=af-1; p3==1?j<af:j>be; p3==1?j++:j--){
                p=j;//j是整形变量,p是字符型变量,这样是将p赋值为ASCII码为j的字符; 
                if(p1==2)//是否大写; 
                    p=(p>='a')?p-32:p;//如果是字母就转成大写 
                else if(p1==3) p='*';//是否输出'*' 
                for(k=0; k<p2; k++)//输出p2个 
                    printf("%c",p);
            }
        } 
        else
            printf("%c",f);//如果ch[i]是非'-'或者其前后不满足条件,就原样输出;
        i++;//一定要放在后面,不然会出错QAQ;
    }
    return 0;
}

我是万万没想到,还有这种操作,直接一个三元运算符,减少了几十行的代码。

总结:

我明白了,我现在不仅仅应该刷题,我还需要掌握好程序语言的一些基础知识,这样对于我未来ACM大有益处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值