这里主要就是用函数和模拟构造
函数:
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;
}