1 条题解
-
0
自动搬运
来自洛谷,原作者为

Narcisuss
**搬运于
2025-08-24 21:20:54,当前版本为作者最后更新于2018-08-08 13:29:15,作者可能在搬运后再次修改,您可在原文处查看最新版自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多
以下是正文
蒟蒻第一次写题解,望通过。
此题看起来很复杂,实践起来其实不是特别难,仔细审题不难发现:影响输出的是p1和p3,p2其实
无关紧要,只要在循环输出的时候作为边界即可。所以我们可以通过三目运算符来
少写几个for循环让代码变得简洁。AC代码:
#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; }
- 1
信息
- ID
- 100
- 时间
- 1000ms
- 内存
- 125MiB
- 难度
- 2
- 标签
- 递交数
- 1
- 已通过
- 1
- 上传者