这里主要就是用函数和模拟构造
函数:
isalpha()判断是否为字母
(char)toupper()变成大写字母,c++一般是返回数字,所以前面要强制转化
这里有个技巧:就是那个for循环,针对只有两种选择的特别好用
for (i:遍历字符串s){ if (s[i]是‘-’&&i不是首或者是尾&&前和后同时字母或数字&&前<后){ for (依p3 从前到后/从后到前){ if (按p1分){ 按p1操作 } } }else 输出s[i] }代码
#include <bits/stdc++.h> using namespace std; int p1,p2,p3; string s; bool isok(char a,char b){ return ((a>='0'&&b<='9')||(a>='a'&&b<='z'))&&a<b; } int main(int argc, char** argv) { cin>>p1>>p2>>p3>>s; for(int i=0;i<s.size();i++){ if(s[i]=='-'&&i!=0&&i!=s.size()-1&&isok(s[i-1],s[i+1])){ for(char j=p3==1?s[i-1]+1:s[i+1]-1;p3==1?j<s[i+1]:j>s[i-1];p3==1?j++:j--){ for(int k=0;k<p2;k++){ if(p1==1){ cout<<j; }else if(p1==2){ if(isalpha((int)j)) cout<<(char)toupper((int)j); else cout<<j; }else { cout<<"*"; } } } }else cout<<s[i]; } return 0; }