字符串展开

在这里插入图片描述
.
.
.
.
.
.
分析
字符类型的模拟题,注意细节就好
开头或结尾可能会有‘-’号,也可能会有‘-----’这种东西。
‘-’前后的字符要同为字母或数字才能展开
对于如何求下一个展开的字符,运用了c++的一些特性
啊,c++ 真玄 真棒
输出时,printf的格式出错了,导致100直接10
啊,printf真好用
.
.
.
.
.
.
程序:

#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int p1,p2,p3;
string t;
char w[1000];
int main()
{
	cin>>p1>>p2>>p3>>t;
	int l=t.length();
	for (int i=l;i>=1;i--)
		w[i]=t[i-1];
	w[0]='-';
	for (int x=1;x<=l;x++)
	{
		if (w[x]==' ') break;
		if (w[x]!='-') 
		{
			printf("%c",w[x]);
			continue;
		}
		char zf1=w[x-1],zf2=w[x+1];
		if (('0'<=zf1&&zf1<='9'&&'a'<=zf2&&zf2<='z')||('0'<=zf1&&zf1<='9'&&'A'<=zf2&&zf2<='Z')||('0'<=zf2&&zf2<='9'&&'a'<=zf1&&zf1<='z')||('0'<=zf2&&zf2<='9'&&'A'<=zf1&&zf1<='Z'))
		{
			cout<<'-';
			continue;
		}
		if (zf1=='-'||zf2=='-') 
		{
			cout<<'-';
			continue;
		}
		if (zf1+1==zf2) continue;
		if (zf1>=zf2)
		{
			cout<<'-';
			continue;
		}
		string zfc="";
		char bj='0';
		int bz=0;
		if ('0'<=zf1&&zf1<='9') bz=1; else
		if ('a'<=zf1&&zf1<='z') bj='a'; else
		if ('A'<=zf1&&zf1<='Z') bj='A';
		for (int i=1;i<=zf2-zf1-1;i++)
			if (p1==1&&bz!=1) zfc=zfc+(char)('a'+(zf1-bj)+i); else 
			if (p1==2&&bz!=1) zfc=zfc+(char)('A'+(zf1-bj)+i); else
			if (p1!=3&&bz==1) zfc=zfc+(char)('0'+(zf1-bj)+i); else
			if (p1==3) zfc=zfc+'*';
		char s[2000];
		if (p3==1)
		{
			for (int i=zfc.length();i>=1;i--)
				s[i]=zfc[i-1];				
		} else
		{
			int l=zfc.length();
			for (int i=l-1;i>=0;i--)
				s[l-i]=zfc[i];
		}
		int len=zfc.length();
		for (int i=1;i<=len;i++)
			for (int j=1;j<=p2;j++)		
				cout<<s[i];
	}
	return 0;
}
### Java字符串展开功能的实现方法 在Java中,“字符串展开”的概念通常指的是将一个压缩形式的字符串转换为其完整的表示形式。例如,给定输入 `"a3b2c"`,其展开后的结果应为 `"aaabbc"`。这种需求可以通过遍历原始字符串并解析其中的数量信息来完成。 以下是基于此逻辑的一个具体实现: #### 代码示例 ```java public class StringExpansion { public static void main(String[] args) { String compressedString = "a3b2c"; StringBuilder expandedString = new StringBuilder(); char currentChar; int count; for (int i = 0; i < compressedString.length(); ) { // 获取当前字符 currentChar = compressedString.charAt(i++); // 解析紧跟在其后的数字部分 StringBuilder numberBuilder = new StringBuilder(); while (i < compressedString.length() && Character.isDigit(compressedString.charAt(i))) { numberBuilder.append(compressedString.charAt(i++)); } // 如果没有跟随的数字,默认重复次数为1 count = numberBuilder.length() > 0 ? Integer.parseInt(numberBuilder.toString()) : 1; // 将字符按指定数量追加到结果中 for (int j = 0; j < count; j++) { expandedString.append(currentChar); } } System.out.println("Expanded String: " + expandedString.toString()); } } ``` 上述代码通过逐一遍历字符串中的每个字符及其后续可能存在的数字部分,实现了字符串的动态扩展。如果某字符后面未跟任何数字,则默认该字符仅需出现一次[^4]。 #### 关键点说明 - **StringBuilder 的使用**:由于 `String` 类型本身不可变,在频繁修改字符串的情况下性能较差。因此采用可变对象 `StringBuilder` 来构建最终的结果。 - **Character.isDigit 方法**:用来检测当前字符是否属于数字范围内的成员,从而决定何时停止读取连续的数值序列[^5]。 #### 性能考量 对于非常长或者复杂的压缩数据而言,这种方法能够有效减少内存占用以及提升运行效率。然而需要注意的是,当面对极端情况(如超大倍率复制单个字母)时仍可能存在资源消耗过高的风险[^6]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值