逻辑运算带括号,去括号不改变运算逻辑

(白血病and心脏病)not(年龄>78not高血压) 类似的带括号的逻辑运算通过方法将括号去掉,但是运算逻辑不变,请问有大佬能给点意见吗?最好java的思路

2个回答

首先看有几个变量,列出0~2的N次方-1的真值表
然后用卡诺图化简。程序的做法也是这个思路

没有,不用想了,这个是运算得先后顺序得问题,()得意思是优先等级和一体得,其他得替代不了

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java 逻辑运算问题,在线等

![图片说明](https://img-ask.csdn.net/upload/201807/09/1531098359_90831.png) 如图所示, 先算a||b 再算c||d 然后再&&运算,应该怎么写

【数据结构】用栈实现的带括号的多位数四则运算器

# 题目原型: 四则运算器:实现多位整数的带括号的四则运算 # # 现存问题: # 1.以下代码利用两个char类型的栈分别存取运算数和运算符,但在结束一次优先级高运算后(考虑到运算精度问题,故在程序中,将每次运算的结果都保存为double型)可能会出现浮点值,这个值必须要压栈,并于下一个优先级产生运算,但这个浮点型值无法压入char型栈中,必须要一位一位存取才可实现,请问有没有比较好的办法解决这个问题,应该怎样将数据压入栈中? # 2.程序中出现如图所示错误,麻烦大佬指点一下原因!![图片说明](https://img-ask.csdn.net/upload/201811/27/1543330782_849826.jpg) ``` #include <stdio.h> #include <stdlib.h> #define TRUE 1 #define FALSE 0 #define Stack_Size 50 typedef char StackElementType; typedef struct { StackElementType elem[Stack_Size]; int Top; }SeqStack; void InitStack(SeqStack *S); int Push(SeqStack *S,StackElementType x); int Pop(SeqStack *S,StackElementType *x); int GetTop(SeqStack *S,StackElementType *x); StackElementType Compare(StackElementType ch1,StackElementType ch2); StackElementType Execute(StackElementType a,StackElementType op,StackElementType b); int main() { printf("%c",ExpEvaluation()); return(0); } StackElementType ExpEvaluation() { SeqStack OPTR,OVS; StackElementType n; StackElementType a,b,ch,op,x,v; InitStack(&OPTR); InitStack(&OVS); Push(&OPTR,'#'); printf("Please input an expression(Ending with #):"); ch=getchar();//为方便,所以数字也以字符形式来存储 while(ch!='#'||GetTop(&OPTR,&x)!='#') { if(ch>='0'&&ch<='9')//不是操作符,是操作数,进OVS栈 { int temp; temp=ch-'0';//先把当前操作数从字符变为数字 ch=getchar(); while(ch>='0'&&ch<='9')//继续判断下一位是否为操作数 { temp=temp*10+ch-'0'; ch=getchar(); } Push(&OVS,temp); } else switch(Compare(ch,GetTop(&OPTR,&x))) { case '>':Push(&OPTR,ch); scanf("%d",&ch); case '=':Pop(&OPTR,&op);ch=getchar();break;//脱括号 case '<':Pop(&OPTR,&op);//形成运算 Pop(&OVS,&b); Pop(&OVS,&a); v=Execute(a,op,b); //此处需要将v转换为字符型并且入站 Push(&OVS,v); break; } } v=GetTop(&OVS,&x); return(v); } //初始化 void InitStack(SeqStack *S) { /*构造一个空栈S*/ S->top=-1; } //进栈 int Push(SeqStack *S,StackElementType x) { if(S->top==Stack_Size-1) return(FALSE); S->top++; S->elem[S->top]=x; return(TRUE); } //出栈 int Pop(SeqStack *S,StackElementType *x) { if(S->top==-1) return(FALSE); *x=S->elem[S->top]; S->top--; return(TRUE); } //读栈顶 int GetTop(SeqStack *S,StackElementType *x) { if(S->top==-1) return(FALSE); else { *x=S->elem[S->top]; return(TRUE); } } //比较优先级,返回'>','<','=' StackElementType Compare(StackElementType ch1,StackElementType ch2) //ch1为还未进栈的运算符,ch2为当前运算符栈顶元素 { //'('未入栈时,优先级最高,入栈后,优先级最低 switch(ch1) { case '(':ch1=6;break; case '*': case '/':ch1=5;break; case '+': case '-':ch1=4;break; case ')':ch1=3;break; } switch(ch2) { case '*': case '/':ch2=5;break; case '+': case '-':ch2=4;break; case ')':ch2=3;break; case '(':ch2=2;break; } if(ch1>ch2) return('>'); else if(ch1=ch2) return('='); else return('<'); } StackElementType Execute(StackElementType a,StackElementType op,StackElementType b) { double v; switch(op) { case '+':v=(double)a+(double)b;break; case '-':v=(double)a-(double)b;break; case '*':v=(double)a*(double)b;break; case '/':v=(double)a/(double)b;break; } return((StackElementType)v); } ```

java,目标是控制台实现带括号的加减乘除运算

新手求教!麻烦大触帮我看下代码,多谢~ 第4次改(依旧错 ``` package com.calculator; import java.io.*; import java.util.regex.*; public class calculator { public static StringBuilder first(StringBuilder s){ int a,b; while(s.indexOf("(")!=-1){ a=s.lastIndexOf(")"); b=s.indexOf(")",a); s.replace(0,b+1,second(new StringBuilder(s.substring(a+1,b))).toString()); } return s; } public static StringBuilder second(StringBuilder s){ Pattern p=Pattern.compile("[-+*/]"); String[] st=p.split(s.toString()); char[] stll=new char[s.length()]; int j=0; for(int i=0;i<s.length();i++){ if(s.charAt(i)=='*') stll[j++]='*'; else if(s.charAt(i)=='/') stll[j++]='/'; else if(s.charAt(i)=='+') stll[j++]='+'; else if(s.charAt(i)=='-') stll[j++]='-'; } char[] st1=new char[j]; System.arraycopy(stll,0,st1,0,j); String[] str=new String[st.length]; int x=0; if(st1[0]=='*'){ str[x]=String.valueOf(Double.parseDouble(st[0])*Double.parseDouble(st[1])); st[1]=str[x]; } else if(st1[0]=='/'){ str[x]=String.valueOf(Double.parseDouble(st[0])/Double.parseDouble(st[1])); st[1]=str[x]; } else if(st1[0]=='+'){ str[x]=st[0]; str[++x]="+"; str[++x]=st[1]; } else if(st1[0]=='-'){ str[x]=st[0]; str[++x]="-"; str[++x]=st[1]; } j=2; for(int i=1;i<st1.length;i++){ if(st1[i]=='*'){ str[++x]=String.valueOf(Double.parseDouble(st[j])*Double.parseDouble(st[++j])); st[j]=str[x]; }else if(st1[i]=='/'){ str[++x]=String.valueOf(Double.parseDouble(st[j])*Double.parseDouble(st[++j])); st[j]=str[x]; }else if(st1[i]=='+'){ str[++x]="+"; str[++x]=st[++j]; }else if(st1[i]=='-'){ str[++x]="-"; str[++x]=st[++j]; } } StringBuilder ss=new StringBuilder(); for(int i=0;i<=x;i++){ ss.append(str[x]); } if(ss.indexOf("+")!=-1||ss.indexOf("-")!=-1){ ss=third(ss); } return ss; } public static StringBuilder third(StringBuilder s){ Pattern p=Pattern.compile("[+-]"); String[] st=p.split(s.toString()); int j=0; for(int i=0;i<s.length();i++){ if(s.charAt(i)=='+'){ j++; st[j]=String.valueOf(Double.parseDouble(st[j-1])+Double.parseDouble(st[j])); } else if(s.charAt(i)=='-'){ j++; st[j]=String.valueOf(Double.parseDouble(st[j-1])-Double.parseDouble(st[j])); } } return new StringBuilder(st[j].trim()); } public static void main(String[] args) { try { BufferedReader in=new BufferedReader(new InputStreamReader(System.in)); String s=in.readLine(); StringBuilder ss=new StringBuilder(s); if(ss.indexOf("(")!=-1) ss=first(ss); else if(ss.indexOf("*")!=-1||ss.indexOf("/")!=-1) ss=second(ss); else ss=third(ss); System.out.println("="+ss); }catch(NumberFormatException e){ System.err.println("NumberFormatException"); e.printStackTrace(); }catch(ArrayIndexOutOfBoundsException e){ System.err.println("ArrayIndexOutOfBoundsException"); e.printStackTrace(); }catch (IOException e) { System.err.println("IOException"); e.printStackTrace(); }catch(Exception e){ System.err.println("Exception"); e.printStackTrace(); } } } ``` 加减运算没问题,第二优先级1步运算没问题,2步开始出错: 2*2*2 > ArrayIndexOutOfBoundsException > java.lang.ArrayIndexOutOfBoundsException: 3 > at com.calculator.calculator.second(calculator.java:50) > at com.calculator.calculator.main(calculator.java:94) (2+3)*2 > Exception > java.lang.StringIndexOutOfBoundsException: String index out of range: -1 > at java.lang.AbstractStringBuilder.substring(Unknown Source) > at java.lang.StringBuilder.substring(Unknown Source) > at com.calculator.calculator.first(calculator.java:10) > at com.calculator.calculator.main(calculator.java:93)

数据结构题目(c语言),把只能实现带小括号的表达式计算改为可以带小中大括号的表达式计算

[链接里是带小括号表达式计算的代码](https://blog.csdn.net/acm_jl/article/details/51031005 "") ![题目要求](https://img-ask.csdn.net/upload/201811/28/1543365503_20006.jpg) 谢谢各位大佬!

汇编语言实现带括号计算器

只要求实现加,减,乘三种运算,要求要进行符号运算,求大神帮助,注释最好多一点

【数据结构】求大佬帮忙看一下这个错误是怎么回事?(用栈实现带括号的多位数四则运算器)

# 题目原型: 四则运算器:实现多位整数的带括号的四则运算 # # 现存问题: # 程序中出现如图所示错误,麻烦大佬指点一下原因 # ![图片说明](https://img-ask.csdn.net/upload/201811/28/1543412646_396920.jpg) # ``` #include <stdio.h> #include <stdlib.h> #define TRUE 1 #define FALSE 0 #define Stack_Size 50 typedef char StackElementType; //运算符 typedef double StackElementType_num; //运算数 typedef struct { StackElementType elem[Stack_Size]; int top; }SeqStack; //运算符栈 typedef struct { StackElementType_num elem[Stack_Size]; int top; }SeqStack_num; //运算数栈 StackElementType_num ExpEvaluation(); void InitStack(SeqStack *S); int Push(SeqStack *S,StackElementType x); int Push_num(SeqStack *S,StackElementType_num x); int Pop(SeqStack *S,StackElementType *x); int Pop_num(SeqStack *S,StackElementType_num *x); int GetTop(SeqStack *S,StackElementType *x); int GetTop_num(SeqStack *S,StackElementType_num *x); StackElementType Compare(StackElementType ch1,StackElementType ch2); StackElementType Execute(StackElementType_num a,StackElementType op,StackElementType_num b); int main() { printf("%lf",ExpEvaluation()); return(0); } StackElementType_num ExpEvaluation() { char exp[100];//用字符数组将运算表达式存起来 int i=0,count=0; printf("Please input an expression (Ending with #:)"); exp[i]=getchar(); while(exp[i]!='#') { i++;count++; exp[i]=getchar(); } SeqStack OPTR; SeqStack_num OVS; StackElementType ch,op,x; StackElementType_num a,b,v; InitStack(&OPTR); InitStack_num(&OVS); Push(&OPTR,'#'); for(i=0;i<count;i++) { ch=exp[i]; while(ch!='#'||GetTop(&OPTR,&x)!='#') { if(ch>='0'&&ch<='9')//不是操作符,是操作数,进OVS栈 { int temp; temp=ch-'0';//先把当前操作数从字符变为数字 i++; ch=exp[i]; while(ch>='0'&&ch<='9')//继续判断下一位是否为操作数 { temp=temp*10+ch-'0'; i++; ch=exp[i]; } Push_num(&OVS,temp);//压栈 } else switch(Compare(ch,GetTop(&OPTR,&x))) { case '>':Push(&OPTR,ch); i++;ch=exp[i]; case '=':Pop(&OPTR,&op);i++;ch=exp[i];break;//脱括号 case '<':Pop(&OPTR,&op);//形成运算 Pop_num(&OVS,&b); Pop_num(&OVS,&a); v=Execute(a,op,b); Push_num(&OVS,v); break; } } } v=GetTop_num(&OVS,&x); return(v); } //初始化 void InitStack(SeqStack *S) { /*构造一个空栈S*/ S->top=-1; } void InitStack_num(SeqStack_num *S) { /*构造一个空栈S*/ S->top=-1; } //进栈 int Push(SeqStack *S,StackElementType x) { if(S->top==Stack_Size-1) return(FALSE); S->top++; S->elem[S->top]=x; return(TRUE); } int Push_num(SeqStack *S,StackElementType_num x) { if(S->top==Stack_Size-1) return(FALSE); S->top++; S->elem[S->top]=x; return(TRUE); } //出栈 int Pop(SeqStack *S,StackElementType *x) { if(S->top==-1) return(FALSE); *x=S->elem[S->top]; S->top--; return(TRUE); } int Pop_num(SeqStack *S,StackElementType_num *x) { if(S->top==-1) return(FALSE); *x=S->elem[S->top]; S->top--; return(TRUE); } //读栈顶 int GetTop(SeqStack *S,StackElementType *x) { if(S->top==-1) return(FALSE); else { *x=S->elem[S->top]; return(TRUE); } } int GetTop_num(SeqStack *S,StackElementType_num *x) { if(S->top==-1) return(FALSE); else { *x=S->elem[S->top]; return(TRUE); } } //比较优先级,返回'>','<','=' StackElementType Compare(StackElementType ch1,StackElementType ch2) //ch1为还未进栈的运算符,ch2为当前运算符栈顶元素 { //'('未入栈时,优先级最高,入栈后,优先级最低 int m,n; switch(ch1) { case '(':m=6;break; case '*': case '/':m=5;break; case '+': case '-':m=4;break; case ')':m=3;break; } switch(ch2) { case '*': case '/':n=6;break; case '+': case '-':n=5;break; case ')':n=4;break; case '(':n=3;break; } if(ch1>ch2) return('>'); else if(ch1=ch2) return('='); else return('<'); } StackElementType_num Execute(StackElementType_num a,StackElementType op,StackElementType_num b) { StackElementType_num v; switch(op) { case '+':v=a+b;break; case '-':v=a-b;break; case '*':v=a*b;break; case '/':v=a/b;break; } return(v); } ```

为什么不能计算带括号的式子?

运行普通算式可以但是不能计算带括号的式子,这是怎么回事? 源文件: ``` #include<iostream.h> #include<ctype.h> #include"stack.h" #include"mathoptr.h" int isoperator(char ch) { return(ch=='+'||ch=='-'||ch=='*'||ch=='/'||ch=='('); } int iswhitespace(char ch) { return(ch==32||ch=='\t'||ch=='\n'); } void Error(char *c) { cerr<<c<<endl; exit(1); } void Evaluate(Stack<double>& Opnds,MathOperator optr) { double opnd1=Opnds.Pop(); double opnd2=Opnds.Pop(); switch(optr.op) { case'+':Opnds.Push(opnd2+opnd1);break; case'-':Opnds.Push(opnd2-opnd1);break; case'*':Opnds.Push(opnd2*opnd1);break; case'/':Opnds.Push(opnd2/opnd1);break; } } int main() { int rank=0; char ch; double number; MathOperator optr1,optr2; Stack<double>opnds; Stack<MathOperator>optrs; cout<<"input an infix:"<<endl; while(cin.get(ch)&&ch!='=') { if(isdigit(ch)||ch=='.') { cin.putback(ch); cin>>number; rank++; if(rank>1) Error("Operator expected!"); opnds.Push(number); } else if(isoperator(ch)) { if(ch!='(') { rank--; } if(rank<0) Error("Operator ecpected!"); optr1=MathOperator(ch); while(!optrs.Empty()&&optrs.Top()>=optr1) { optr2=optrs.Pop(); Evaluate(opnds,optr2); } optrs.Push(optr1); } else if(ch==')') { optr1=MathOperator(ch); while(!optrs.Empty()&&optrs.Top()>=optr1) { optr2=optrs.Pop(); Evaluate(opnds,optr2); } if(optrs.Empty()) { Error("Missing left parenthesis"); } optrs.Pop(); } else if(!iswhitespace(ch)) Error("Invalid input!"); } if(rank!=1) Error("operator expected!"); while(!optrs.Empty()) { optr2=optrs.Pop(); if(optr2.op=='(') Error("Missing right paernthesis"); Evaluate(opnds,optr2); } cout<<"The value is "<<opnds.Pop()<<endl; return 0; } ``` 两头文件: ``` #include<stdlib.h> template <class T> class List { private: struct Node { T data; Node * prev,*next; Node(const T &d=T(),Node *p=NULL,Node *n=NULL):data(d),prev(p),next(n){} }; int size; Node* head; Node* tail; void Init() {size=0;head=new Node;tail=new Node;head->next=tail;tail->prev=head;} public: class const_iterator { protected: Node *current; T& retrieve()const{return current->data;} const_iterator(Node *p):current(p){} friend class List<T>; public: const_iterator():current(NULL){} const T& operator*()const{return retrieve();} const_iterator& operator++() { current=current->next; return *this; } const_iterator operator++(int) { const_iterator old=*this; ++(*this); return old; } const_iterator& operator--() { current->prev; return *this; } const_iterator operator--(int) { const_iterator old=*this; --(*this); return old; } bool operator==(const const_iterator& rhs)const {return current==rhs.current;} bool operator!=(const const_iterator & rhs)const {return current!=rhs.current;} }; class iterator:public const_iterator { protected: iterator(Node *p):const_iterator(p){} friend class List<T>; public: iterator(){} T& operator*(){return retrieve();} const T& operator*()const{return const_iterator::operator *();} iterator& operator++() { current=current->next; return *this; } iterator operator ++(int) { iterator old=*this; ++(*this); return old; } iterator & operator--() { current=current->prev; return *this; } iterator operator--(int) { iterator old=*this; --(*this); return old; } }; List(){Init();} List(const List<T> &l){Inti();operator=(l);} ~List(){Clear();delete head;delete tail;} const List& operator=(const List& l); int Size()const{return size;} bool Empty()const{return size==0;} void Clear(){while(!Empty())Pop_front();} iterator Erase(iterator itr); iterator Insert(iterator,const T& item); iterator Begin(){return iterator(head->next);} const_iterator Begin()const{return iterator(head->next);} iterator End(){return iterator(tail);} const_iterator End()const{return iterator(tail);} T& Front(){return *Begin();} const T& Front()const{return *Begin();} T& Back(){return *--End();} const T& Back()const{return *--End();} void Push_front(const T& item){Insert(Begin(),item);} void Push_back(const T& item){Insert(End(),item);} void Pop_front(){Erase(Begin());} void Pop_back(){Erase(--End());} }; template<class T> const List<T>& List<T>::operator =(const List<T>& l) { Clear(); for(const_iterator itr=l.Begin();itr!=l.End();++i) Push_back(*itr); return *this; } template<class T> List<T>::iterator List<T>::Erase(iterator itr) { Node*p=itr.current; iterator re(p->next); p->prev->next=p->next; p->next->prev=p->prev; delete p; size--; return re; } template<class T> List<T>::iterator List<T>::Insert(iterator itr,const T& item) { Node *p=itr.current; size++; p->prev->next=new Node(item,p->prev,p); p->prev=p->prev->next; return iterator(p->prev); } template<class T> class Stack { List<T>stackL; public: Stack(){} ~Stack(){} int Size()const{return stackL.Size();} int Empty()const{return stackL.Empty();} const T& Top()const{return stackL.Back();} T Pop(){T item=stackL.Back();stackL.Pop_back();return item;} void Push(const T& item) {stackL.Push_back(item);} void Clear(){stackL.Clear();} }; struct MathOperator { char op; int ipre,spre; explicit MathOperator(char ch='+'); bool operator>=(MathOperator optr)const{return (spre>=optr.ipre);} }; MathOperator::MathOperator(char ch) { op=ch; switch(op) { case'+': case'-':ipre=1;spre=1;break; case'/': case'*':ipre=2;spre=2;break; case'(':ipre=3;spre=-1;break; case')':ipre=0;spre=0;break; } } ```

括号能否改变求值顺序?

我想不出例子。 《C++ Primer》第五版,中文版。123 页。

C语言写一算法,对输入的表达式中括号匹配情况检查。匹配的括号需要成对出现,且不嵌套。

任务描述 写一算法,对输入的表达式中括号匹配情况检查。匹配的括号需要成对出现,且不嵌套。 输入 第1行为一个整数t(1≤t≤10),表示接下来有t 个测试数据。 第2行输入被检查的表达式。 输出 括号是否匹配。 输入举例 4 ([{}()]) ([({})) [(})({}) ([{})] 输出举例 Match! Not match! Not match! Not match!

C语言 用栈实现 括号匹配

符号匹配(50分) 题目内容: 判断输入的括号字符串是否匹配, 括号有()、[]、{}、<>四种, 匹配的定义如下: (1) 空字符串为匹配。 (2) 若S为匹配字符串,则(S)、[S]、{S}、<S>为匹配自串。 (3) 两个匹配字符串串接亦为匹配字符串。 输入格式: 输入第一行为一个数字T,代表测试数据的笔数。 接下来会有T笔测试数据,每一笔测试数据一行。 每一笔测试数据的字符串长度不超过2000字符。 T < 1000 输出格式: 输出一行数字,输出测资中有多少匹配字符串。 输入样例: 5 () <><>[] ([{[]}]) <()){} 输出样例: 4

正则表达式如何判断括号内是否内嵌了括号?

例如:输入 ......(123)(456)...... 输出true 输入 ......(123(456))...... 输出false 在任意长的一串字符中,如果出现了内嵌括号,就输出false 求教,谢谢各位大神了。

实现以下四则运算计算器的设计:

优化界面布局及控件的合理使用 优化操作体验 合理的代码结构 必要的语法检查逻辑(括号配对、运算符号重叠、运算数丢失) ![图片说明](https://img-ask.csdn.net/upload/201906/25/1561451033_253514.png) 希望程序可以具体一点。

OpenJudge一类括号匹配问题

总时间限制: 1000ms 内存限制: 65536kB 描述 在程序设计中,常常使用小括号强调表达式的运算顺序,但是,左右小括号必须匹配。现给定一个不多于500个符号的表达式(串),其中可能存在多个小括号,想检查小括号的匹配问题。如果存在小括号不匹配,则输出 mismatch;如果所有小括号匹配,则按左右括号的匹配距离由小到大输出左、右括号的位置;若多个匹配的距离相等,则左括号先出现的匹配先输出;如果整个串中没有小括号,则左右位置均输出0,即 0,0; ,规定,串中第一个符号的位置为1。 匹配距离=右括号位置 - 左括号位置。 例如: 输入为: (x+y*(z-5)*(x+y))*(x+98) 输出为: 6,10 12,16 19,24 1,17 如果输入为 (x+y*(z-5))*x+y) 则不匹配,因为在最后的反括号没有相匹配的正括号。因此,输出: mismatch 输入 一串符号 输出 按匹配距离的增序输出匹配对的左右位置,逗号间隔;如果距离相同,则按左括号出现的先后顺序输出;如果整个序列中出现不匹配现象,则输出 mismatch; 样例输入 (x+y*(z-5)*(x+y))*(x+98) 样例输出 6,10 12,16 19,24 1,17

SQL 四则运算优先级语句

1+2[]*5[]/4[]-6[]=结果 首先呢中括号里面的是对前面那个数的备注,解释,没有作用。我们要建立一个存储过程,接收前台传入的这一整个参数‘1+2[]*5[]/4[]-6[]’,接着呢将中括号以及中括号中的备注去除,得出运算过程,接着根据加减乘除运算法则进行运算,返回最后值,也就是简单说写个存储过程,去掉[XXXX],然后得到1+2*5/4-6,然后按加减乘除运算优先级一步步算。请问在SQL Server中要如何写语句?

安卓计算器实现如何实现连续运算

package com.imooc.calculator; import java.util.ArrayList; import java.util.Arrays; import bsh.EvalError; import bsh.Interpreter; import android.app.Activity; import android.app.AlertDialog; import android.app.AlertDialog.Builder; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.TextView; public class MainActivity extends Activity implements OnClickListener { Button btn_0; Button btn_1; Button btn_2; Button btn_3; Button btn_4; Button btn_5; Button btn_6; Button btn_7; Button btn_8; Button btn_9; Button btn_point;// 小数点 Button btn_divide;// 除以 Button btn_multiply;// 乘以 Button btn_minus;// 减去 Button btn_pluse;// 加 Button btn_equal;// 等于 Button btn_clear; Button btn_del; private EditText et_showview; boolean needclear; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn_0 = (Button) findViewById(R.id.btn_0); btn_1 = (Button) findViewById(R.id.btn_1); btn_2 = (Button) findViewById(R.id.btn_2); btn_3 = (Button) findViewById(R.id.btn_3); btn_4 = (Button) findViewById(R.id.btn_4); btn_5 = (Button) findViewById(R.id.btn_5); btn_6 = (Button) findViewById(R.id.btn_6); btn_7 = (Button) findViewById(R.id.btn_7); btn_8 = (Button) findViewById(R.id.btn_8); btn_9 = (Button) findViewById(R.id.btn_9); btn_point = (Button) findViewById(R.id.btn_point);// 小数点 btn_divide = (Button) findViewById(R.id.btn_divide);// 除以 btn_multiply = (Button) findViewById(R.id.btn_multiply);// 乘以 btn_minus = (Button) findViewById(R.id.btn_minus);// 减去 btn_pluse = (Button) findViewById(R.id.btn_pluse);// 加 btn_equal = (Button) findViewById(R.id.btn_equal);// 等于 btn_clear = (Button) findViewById(R.id.btn_clear); btn_del = (Button) findViewById(R.id.btn_del); et_showview = (EditText) findViewById(R.id.et_showview); btn_0.setOnClickListener(this); btn_1.setOnClickListener(this); btn_2.setOnClickListener(this); btn_3.setOnClickListener(this); btn_4.setOnClickListener(this); btn_5.setOnClickListener(this); btn_6.setOnClickListener(this); btn_7.setOnClickListener(this); btn_8.setOnClickListener(this); btn_9.setOnClickListener(this); btn_point.setOnClickListener(this); btn_divide.setOnClickListener(this); btn_multiply.setOnClickListener(this); btn_minus.setOnClickListener(this); btn_pluse.setOnClickListener(this); btn_equal.setOnClickListener(this); btn_clear.setOnClickListener(this); btn_del.setOnClickListener(this); } @Override public void onClick(View v) { // TODO Auto-generated method stub String str = et_showview.getText().toString(); switch (v.getId()) { case R.id.btn_0: case R.id.btn_1: case R.id.btn_2: case R.id.btn_3: case R.id.btn_4: case R.id.btn_5: case R.id.btn_6: case R.id.btn_7: case R.id.btn_8: case R.id.btn_9: case R.id.btn_point: if(needclear){ needclear=false; str = ""; et_showview.setText(""); } et_showview.setText(str + ((Button) v).getText()); break; case R.id.btn_pluse: case R.id.btn_minus: case R.id.btn_multiply: case R.id.btn_divide: if(needclear){ needclear=false; str = ""; et_showview.setText(""); } et_showview.setText(str +" "+((Button) v).getText()+" "); break; case R.id.btn_equal: getResult(); break; case R.id.btn_del: if(str != null && !str.equals("")) { et_showview.setText(str.substring(0, str.length() - 1)); } break; case R.id.btn_clear: needclear=false; str = ""; et_showview.setText(""); break; } } /** * 获取计算结果 */ private void getResult() { needclear = true; String exp = et_showview.getText().toString(); double r = 0; //当我们的输入框是null或者""时我们不进行操作 if (exp == null || exp.equals(" ")) { return; } //要计算结果,必须知道输入框是否有操作符,判断条件就是前后是否在空格,否则不进行操作 if (!exp.contains(" ")) { //没有运算符,所以不用运算 return; } int space = exp.indexOf(' ');//用于搜索空格位置 String s1 = exp.substring(0, space);//s1用于保存第一个运算数 String op = exp.substring(space + 1, space + 2);//op用于保存运算符 String s2 = exp.substring(space + 3);//s2用于保存第二个运算数 double arg1 = Double.parseDouble(s1);//将运算数从string转换为Single double arg2 = Double.parseDouble(s2); if(op.equals("+")){ r = arg1 + arg2; }else if(op.equals("-")){ r = arg1 - arg2; }else if(op.equals("×")){ r = arg1 * arg2; }else if(op.equals("÷")){ //除数为0不计算 if (arg2 == 0) { AlertDialog.Builder builder = new Builder(MainActivity.this); builder.setTitle("警告" ) ; builder.setMessage("零不能做分母" ) ; builder.setPositiveButton("确定" , null ); builder.show(); } else { r = arg1 / arg2; } } if(!s1.contains(".")&&!s2.contains(".")){ int result = (int)r; et_showview.setText(result+""); }else{ et_showview.setText(r+""); } } }

51单片机和lcd1602实现可以混合运算的计算器

4*4矩阵按键,可以进行1+2*3=7这种混合运算,不需要小数和括号,求程序!

用C语言编写能进行四则运算的程序

我想用C语言编一个能进行简单的四则运算的程序,应该怎么写,请详细解释一下输入和计算部分

c++ 堆栈四则运算括号操作程序查错的问题

这个程序可以输入例如((80+50)*3) 但是为什么会停止工作?这是书上的例程啊... #include<cctype> #include<cstdlib> #include<cstring> #include<iostream> #include<stack> using namespace std; double read_and_evaluate(istream& ins); void evaluate_stack_tops(stack<double>& numbers, stack<char>& operations); int main() { double answer; cout<<"TYPE expression"<<endl; answer = read_and_evaluate(cin); cout << "that evaluates to" << answer << endl; system("pause"); } double read_and_evaluate(istream& ins) { const char DECIMAL = '.'; const char RIGHT_PARENTHESIS = ')'; stack<double> numbers; stack<char> operations; double number; char symbol; while(ins && ins.peek()!='\n') { if(isdigit(ins.peek()) || (ins.peek() == DECIMAL)) { ins >> number; numbers.push(number); } else if(ins.peek() == RIGHT_PARENTHESIS) { ins.ignore(); evaluate_stack_tops(numbers, operations); } else ins.ignore(); } return numbers.top(); } void evaluate_stack_tops(stack<double>& numbers, stack<char>& operations) { double operand1,operand2; operand2=numbers.top(); numbers.pop(); operand1=numbers.top(); numbers.pop(); switch(operations.top()) { case '+': numbers.push(operand1+operand2); break; case '-': numbers.push(operand1-operand2); break; case '*': numbers.push(operand1 * operand2); break; case '/': numbers.push(operand1/operand2); break; } operations.pop(); }

用c++写一个计算器,要求有加减乘除括号,这5个功能

我自己写了一个,无奈各种异常终止程序,求问各路大侠支招,有没有什么思路…谢谢了先

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

实现简单的文件系统

实验内容: 通过对具体的文件存储空间的管理、文件的物理结构、目录结构和文件操作的实现,加深对文件系统内部功能和实现过程的理解。 要求: 1.在内存中开辟一个虚拟磁盘空间作为文件存储器,在其上实现一个简

MIPS单周期CPU-组成原理实验-华中科技大学

使用logisim布线完成的MIPS单周期CPU,可支持28条指令。跑马灯的代码已经装入了寄存器,可以直接开启时钟运行。

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

基于QT和OpenCV的五子棋实现源码

一个简单的五子棋应用,基于QT和OpenCV的实现源码,通过相邻棋子判断是否获胜,不包含人工智能算法,适合新手入门

Git 实用技巧

这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

C/C++跨平台研发从基础到高阶实战系列套餐

一 专题从基础的C语言核心到c++ 和stl完成基础强化; 二 再到数据结构,设计模式完成专业计算机技能强化; 三 通过跨平台网络编程,linux编程,qt界面编程,mfc编程,windows编程,c++与lua联合编程来完成应用强化 四 最后通过基于ffmpeg的音视频播放器,直播推流,屏幕录像,

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

linux“开发工具三剑客”速成攻略

工欲善其事,必先利其器。Vim+Git+Makefile是Linux环境下嵌入式开发常用的工具。本专题主要面向初次接触Linux的新手,熟练掌握工作中常用的工具,在以后的学习和工作中提高效率。

JAVA初级工程师面试36问(完结)

第三十一问: 说一下线程中sleep()和wait()区别? 1 . sleep()是让正在执行的线程主动让出CPU,当时间到了,在回到自己的线程让程序运行。但是它并没有释放同步资源锁只是让出。 2.wait()是让当前线程暂时退让出同步资源锁,让其他线程来获取到这个同步资源在调用notify()方法,才会让其解除wait状态,再次参与抢资源。 3. sleep()方法可以在任何地方使用,而wait()只能在同步方法或同步块使用。 ...

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

智鼎(附答案).zip

并不是完整题库,但是有智鼎在线2019年9、10、11三个月的试题,有十七套以上题目,普通的网申行测题足以对付,可以在做题时自己总结一些规律,都不是很难

Visual Assist X 破解补丁

vs a's'sixt插件 支持vs2008-vs2019 亲测可以破解,希望可以帮助到大家

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

JavaWEB商城项目(包括数据库)

功能描述:包括用户的登录注册,以及个人资料的修改.商品的分类展示,详情,加入购物车,生成订单,到银行支付等!另外还有收货地址的和我的收藏等常用操作.环境(JDK 1.7 ,mysql 5.5,Ecli

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

一学即懂的计算机视觉(第一季)

图像处理和计算机视觉的课程大家已经看过很多,但总有“听不透”,“用不了”的感觉。课程致力于创建人人都能听的懂的计算机视觉,通过生动、细腻的讲解配合实战演练,让学生真正学懂、用会。 【超实用课程内容】 课程内容分为三篇,包括视觉系统构成,图像处理基础,特征提取与描述,运动跟踪,位姿估计,三维重构等内容。课程理论与实战结合,注重教学内容的可视化和工程实践,为人工智能视觉研发及算法工程师等相关高薪职位就业打下坚实基础。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/26281 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,但是大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/26281,点击右下方课程资料、代码、课件等打包下载

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

2019 Python开发者日-培训

本次活动将秉承“只讲技术,拒绝空谈”的理念,邀请十余位身处一线的Python技术专家,重点围绕Web开发、自动化运维、数据分析、人工智能等技术模块,分享真实生产环境中使用Python应对IT挑战的真知灼见。此外,针对不同层次的开发者,大会还安排了深度培训实操环节,为开发者们带来更多深度实战的机会。

快速入门Android开发 视频 教程 android studio

这是一门快速入门Android开发课程,顾名思义是让大家能快速入门Android开发。 学完能让你学会如下知识点: Android的发展历程 搭建Java开发环境 搭建Android开发环境 Android Studio基础使用方法 Android Studio创建项目 项目运行到模拟器 项目运行到真实手机 Android中常用控件 排查开发中的错误 Android中请求网络 常用Android开发命令 快速入门Gradle构建系统 项目实战:看美图 常用Android Studio使用技巧 项目签名打包 如何上架市场

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

相关热词 c#中如何设置提交按钮 c#帮助怎么用 c# 读取合并单元格的值 c#带阻程序 c# 替换span内容 c# rpc c#控制台点阵字输出 c#do while循环 c#调用dll多线程 c#找出两个集合不同的
立即提问