思路:
按照要求模拟即可,主要是别忘了,在遇到运算符时,除了出在当前栈中,栈顶元素优先级较高的元素之外,还要将当前的运算符入栈
1、整体的规则,遇到字符直接输出
2、遇到左括号直接入栈
3、遇到右括号,直接出栈,直到出栈元素为左括号
4、遇到 ‘’ ‘/’ 将栈顶中符号为’’ ‘/‘出栈,直到为空,或者遇到括号,然后将当前操作符入栈
5、遇到’+’,‘-‘将栈顶中符号为 ‘+’,’-’,‘*’ ‘/’ 全部出栈 ,然后将当前操作符入栈
6、最后栈不为空,输出所有元素
代码:
char *InToPost(char *s){int n = strlen(s),top=-1,i=0,j=0;char stack[maxsize];char *ans = (char *)malloc(sizeof(char)*n);while(s[i]!='\0'){if((s[i]>'a' && s[i] < 'z') || (s[i]>'A' && s[i] < 'Z')){ //1、如果是字符 ,直接输出 ans[j++] = s[i];i++;}else if(s[i]=='('){ //2、如果是左括号,直接入栈 stack[++top] = s[i++]; }else if(s[i]==')'){ //3、如果是右括号,出栈 while(stack[top]!='('){ans[j++] = stack[top--];}top--; //将'('出栈 i++;}else if(s[i] == '*' || s[i]=='/'){ //4、如果是乘法,或者除法 while(top!=-1 &&( stack[top]=='*' || stack[top] == '/')){ans[j++] = stack[top--];}stack[++top] = s[i++]; //将当前操作符,入栈 }else{ //5、如果是减法、加法 while(top!=-1 && stack[top]!='('){ans[j++] = stack[top--];}stack[++top] = s[i++]; //将当前操作符,入栈 } }while(top!=-1){ //6、输出栈中剩余元素 ans[j++] = stack[top--];} return ans;
}
思路:
代码:
char Judge(char ch){ //返回对应的括号 if(ch == '}') return '{';if(ch == ']') return '[';if(ch == ')') return '(';return 0;
}bool IsValid(char * s){int len = strlen(s),top = 0;char stack[len+1],ch;if(len%2==1) return false; //长度不符 for(int i = 0;ich = judge(s[i]);if(ch){ //当前返回的是左括号 if( top==0 || stack[top-1] != ch) //匹配失败 return false;top--; //匹配成功,出栈 }else{ //如果是左括号,入栈 str[top++] = s[i];}}return top==0; //栈空才匹配成功
}
十进制转为r进制
其实进制转换用不用栈都可以,只是栈比较形象些
思路:
代码:
// 10进制转为r进制
int *BaseChange(int n, int r){int stack[maxsize], top = -1,num;while(n!=0){ num = n%r; stack[++top] = num;n = n/r;} //此时,栈中保存对应r进制数的逆序,不断出栈便可得到对应的r进制数 while(top!=-1){printf("%d",stack[top--]);}
}