public class Indexof {
public static void main(String[] args) {
//这个字符串长度为8,第一个值0,最后一个位置7
//注意特殊数字10,10分成两位是1和0,两位代表一个数字
//作业:
//考虑1\没有括号,2\有1个括号
//3\两个括号
//(5+3)*(1+2)
//2+2+2*10
//其它情况
// String biaoda="5*6*8/10";
// String biaoda="(5+2+K)*3";
String biaoda="2+2+2*10";
System.out.println(biaoda.indexOf("("));
//indexOf输出字符串中的第0个位置,可以输出右括号在字符串的位置,这个位置从0开始
//把字符串拆开,每一个是一个字符,就是char,在字符串有函数charAt(位置)
System.out.println(biaoda.indexOf(")"));
//这里把(开始位置定义变量,把)结束位置定义变量,中间的可以进行有效性判断和计算
int index_first=biaoda.indexOf("(");
// if(index_first==-1){
// index_first=-1;
// }
int index_last=biaoda.indexOf(")");
if(index_last==-1){
//字符串有长度函数length()
index_last=biaoda.length();
}
//和差积商的计算结果有一值放在循环外
int num1=0;
//把记录的flag做一个全局,给flag一个没有的符号初始化
char flag='|';
//全局有传有收
num1=test_for(index_first+1,index_last,num1,biaoda,flag);
if(index_last<biaoda.length()){
num1=test_for(index_last+1,biaoda.length(),num1,biaoda,flag);
}
//再计算括号外面的结果
//循环计算结束,打印全局的num1
System.out.println(num1);
}
//函数需要根据flag来做事情,所以传入flag,凡是出现变量报错,证明这段函数需要变量,再把变量做参数传入,
//函数中缺少计算的量,采用传参就可以
//这个函数中有主函数中的全局,num1是主函数的全局,只要有全局,把全局返回
//默认返回是void,是空,把void改成返回全局的int
public static int test_switch(char flag,int num1,int num2){
// System.out.println("---------------------");
// System.out.println(num2);
//如果num2传入一个0,证明num2之前的数字1,num1已加过一个1
switch(flag){
case '|':
//证明没有操作
if (num2==0) {
num1 += 9;
}else{
num1=num2;
}
break;
case '+':
//加减乘除=后面的数值还是需要变化,不是固定的1
if (num2==0){
num1+=9;
}else{
num1+=num2;
}
break;
case '-':
if (num2==0){
num1-=9;
}else{
num1-=num2;
}
break;
case '*':
//num2是0,不能做乘法
if(num2!=0){
num1*=num2;
}else{
num1*=10;
}
break;
case '/':
//num2,不能做除法
if(num2!=0){
num1/=num2;
}else{
num1/=10;
}
}
//如果有全局,在计算中还有全局变量参与,最后返回全局
return num1;
}
//复制后,错的标红的作输入变量,
//函数里:如果大括号没有错误,看一下返回值
public static int test_for(int start,int end,int num1,String biaoda,char flag) {
// for(int i=index_first+1;i<index_last;i++){
for (int i = start; i < end; i++) {
// System.out.println(biaoda.charAt(i));
//()内的字符全部取出,碰到数字记录,一个加法的和是由被加数和加数决定的
//这是记录加数和被加数的;也可以sum和num的关系,num是记数的,sum是求和的
//charAt(i)输出的字符可能是J ,Q,K。如果直接接收整型不合适,这里用一个中间变量
//这里把num1记录当前的字符
// int num1=0;
char num1_mid = biaoda.charAt(i);
//记录操作的标志位,放在循环里面,每次循环flag定义一次,每次循环flag变化,不能让flag发生变化,
//记录的操作在遇到第二个操作数之前都是有效的。所以flag应该是全局
//记录标志位后,只有再有一个数,就可以使用
//如果是J,Q,K就转化成1
switch (num1_mid) {
case 'J':
//把后面的switch复制到每一个switch里面,这段代码才能一直有效
//这里简化操作,把这段不断重复,影响结构的代码提出来,变成一个函数,函数名不能是main,前面的内容一致
//注意test_switch有结果返回,有结果返回就要接收,使用全局来接收
num1 = test_switch(flag, num1, 1);
// num1+=1;
break;
case 'Q':
num1 = test_switch(flag, num1, 1);
// num1+=1;
break;
case 'K':
num1 = test_switch(flag, num1, 1);
// num1+=1;
break;
case '+':
//当加减乘除任一开始操作时,只有一个数存在,不能做任何运算,只能等另一个数过来,才能运算
//遇到这类问题,你把这个符号当作标志位
flag = '+';
break;
case '-':
//只记录,不能计算
flag = '-';
break;
case '*':
flag = '*';
break;
case '/':
flag = '/';
break;
default:
// System.out.println(Integer.parseInt(num1_mid+""));
num1 = test_switch(flag, num1, Integer.parseInt(num1_mid + ""));
//把char型加上一个字符,只不过这个字符是""
// num1+=Integer.parseInt(num1_mid+"");
}
//一个一个打印,看错误的原因
// System.out.println(num1);
//如果碰到加减乘除,就把这两个数计算
}
return num1;
}
}