字符串运算java简单实现,没有优化,没有大批量的测试。


import java.util.ArrayList;
import java.util.List;

public class MathString {

public static void main(String[] args){
String press = "12*12.22-7*(23.45-(-2))+(12-34)";
press = press.replaceAll("[\\[\\{]", "(").replaceAll("[\\]\\}]", ")");
System.out.println(parseString(press));
}

public static String parseString(String press){
int lasc = press.lastIndexOf("(");
if(lasc==-1){
return String.valueOf(addString(press));
}

String firstKHString = press.substring(0,lasc);
String lastFKHString = press.substring(lasc+1);
//System.out.println("firstKHString---"+firstKHString);
//System.out.println("lastFKHString---"+lastFKHString);

int firc = lastFKHString.indexOf(")");
lastFKHString = press.substring(firc+lasc+2);
//System.out.println("lastFKHString---"+lastFKHString);
String currentPress = press.substring(lasc+1,firc+lasc+1);
//System.out.println(currentPress);

return parseString(firstKHString+addString(currentPress)+lastFKHString);

}

public static double addString(String press){
//System.out.println(press);
press = repAddString(press);
press = repString(press);
//System.out.println(press);
String[] numbers = press.split("[\\+]");
double number = 0;

List<String> fhs = getFHAdd(press);
for(int i=0 ; i<numbers.length; i++ ){
String curNum = numbers[i];
//System.out.println(curNum);
if(curNum.equals("")){
curNum="0";
}
if(fhs.get(i).equals("+")){
number = number + mathString(curNum);
}else if(fhs.get(i).equals("-")){
number = number - mathString(curNum);
}
}
return number;
}

public static double mathString(String press){
/*int firstCH = press.indexOf("*");
int firstC = press.indexOf("/");
if(firstCH == -1 && firstC == -1){
return Double.parseDouble(press);
}
int firstindex = firstC < firstCH ? firstC : firstCH;
*/
press = repAddString(press);
String[] numbers = press.split("[\\*\\/]");
List<String> fhs = getFH(press);
double result = 1;
for(int i=0 ; i<numbers.length; i++){
if(fhs.get(i).equals("*")){
result = result * Double.parseDouble(numbers[i]);
}else if(fhs.get(i).equals("/")){
if(Double.parseDouble(numbers[i])==0){
throw new ArithmeticException("表达式中被除数有空值!");
}
result = result / Double.parseDouble(numbers[i]);
}
}
return result;
}



public static String repAddString(String press){
return press.replace("++", "+").replace("--", "+").replace("+-", "-").replace("-+", "-");
}

public static String repString(String press){
StringBuffer sb = new StringBuffer();
char ch = 0;
for(char c:press.toCharArray()){
if(c=='-'&&'/'!=ch&&'*'!=ch){
sb.append("+");
}
ch = c;
sb.append(c);
}
return sb.toString();
}
public static List<String> getFH(String press){
char[] chars = press.toCharArray();
List<String> fhs = new ArrayList<String>();
fhs.add("*");
for(char c : chars){
if(c=='*' || c=='/'){
fhs.add(String.valueOf(c));
}
}
return fhs;
}

public static List<String> getFHAdd(String press){
char[] chars = press.toCharArray();
List<String> fhs = new ArrayList<String>();
fhs.add("+");
for(char c : chars){
if(c=='+'){
fhs.add(String.valueOf(c));
}
}
return fhs;
}

}
这些文档涵盖了5G网络优化的多个方面,包括**载波聚合、干扰管理、负载均衡、电调核查等**。以下是对这些文档内容的详细总结: #### **5G网络优化中的载波聚合技术** - **载波聚合的定义和作用**: - 载波聚合(CA)是3GPP在Release 10阶段引入的技术,通过将多个连续或非连续的载波聚合成更大的带宽,提高整网资源利用率和用户体验。 - **开启步骤及脚本**: - 确认站内是否有CA License。 - 添加CA组并配置相关参数。 - 基站盲配置开关打开,激活门限设置,增加CA小区集辅小区配置。 - **载波聚合A5测量事件开关的作用**: - A5测量事件开关打开时,支持CA的UE会A4转A5,调整A5门限1到-43dBm,类似于走A4事件触发异频切换。 - 关闭时,当UE处于载波聚合状态下才会将A4转A5,但不会调整A5门限1。 #### **干扰管理和优化** - **系统外干扰**: - 信号放大器和信号屏蔽器是主要的干扰源。解决建议包括协调推进信号放大器关、替、拆工作,引导用户使用VOLTE业务,以及联系公安进行收缴关闭信号屏蔽器。 - **系统内干扰**: - 包括杂散干扰、阻塞干扰和互调干扰。解决方法包括调整天面、增加隔离度,加装滤波器等。 #### **移动性负载均衡(MLB)配置方案** - **背景描述**:随着LTE用户数的快速发展,部分小区的用户数或PRB利用率已接近容量极限。MLB是指eNodeB判断小区的负载状态,当小区处于高负载状态时,将负载高小区中部分UE转移到负载低的小区,平衡异频或异系统之间的负载。 - **方案分析与实施**: - 方案介绍:MLB分为触发模式、选择目标小区、负载均衡执行三个阶段。根据这三个维度可划分为以下各种类型。 - 配置原则:确定候选邻区,交互负载信息,识别交互邻区和盲邻区,确定目标小区列表。 - 均衡执行:现网采用切换的方式转移同步态用户,RRC connection release方式转移空闲态用户。 - 三种均衡方式的优缺点对比:异频同步态用户数均衡(转移同步态用户)、异频同步态用户数均衡(转移空闲态用户)、异频空闲态UE预均衡。 #### **FDD电调核查及修改方法** - **FDD侧电调修改方法**:查询电调天线配置信息和子单元配置信息,可以查询/修改电子下倾角。 - **GSM侧电调修改方法**:查询天线设备编号、框槽号及天线设备序列号等信息。 - **常见的天线类型及匹配问题**:HW天线是现网绝大多数天线类型,需特别注意设备厂家编码和设备序列号的匹配问题。 综上所述,这些文档详细介绍了5G网络优化中的关键技术和方法,从载波聚合到干扰管理再到移动性负载均衡和FDD电调核查等方面提供了全面的指导和解决方案。通过这些内容的学习和应用,可以有效提升5G网络的性能和用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值