首页技术substring(1?string类型比较大小

substring(1?string类型比较大小

编程之家2026-06-12953次浏览

很多朋友对于substring(1和string类型比较大小不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!

substring(1?string类型比较大小

java中str =str.subString(1,3);是什么意思

public String substring(int beginIndex,int endIndex,返回一个新字符串,它是此字符串的一个子字符串。该子字符串从指定的 beginIndex处开始,直到索引 endIndex- 1处的字符。因此,该子字符串的长度为 endIndex-beginIndex。

链接:

拓展:

1、Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。

2、Java是由Sun Microsystems公司推出的Java面向对象程序设计语言(以下简称Java语言)和Java平台的总称。由James Gosling和同事们共同研发,并在1995年正式推出。Java最初被称为Oak,是1991年为消费类电子产品的嵌入式芯片而设计的。1995年更名为Java,并重新设计用于开发Internet应用程序。用Java实现的HotJava浏览器(支持Java applet)显示了Java的魅力:跨平台、动态Web、Internet计算。从此,Java被广泛接受并推动了Web的迅速发展,常用的浏览器均支持Javaapplet。另一方面,Java技术也不断更新。Java自面世后就非常流行,发展迅速,对C++语言形成有力冲击。在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。2010年Oracle公司收购Sun Microsystems。

Java怎么实现输入一个string表达式然后输出计算的结果

import java.io.*;

substring(1?string类型比较大小

import java.util.*;

class BinaryTree{

BinaryTree left=null;

BinaryTree right=null;

char data=0;

}

substring(1?string类型比较大小

public class Calculator{

String porder="";

public void postorder(BinaryTree bt){

//递归后序遍历二叉树

if(bt!=null){

postorder(bt.left);

postorder(bt.right);

porder+=bt.data;

}

}

public int calc(String s){

//计算后缀表达式的值

int i=0,len=0,a=0,b=0;

Stack stack=new Stack();

len=s.length();

for(;i<len;i++){

char c=s.charAt(i);

switch(c){

case'+':

a=(int)stack.pop();

b=(int)stack.pop();

stack.push(a+b);

break;

case'-':

b=(int)stack.pop();

a=(int)stack.pop();

stack.push(a-b);

break;

case'*':

a=(int)stack.pop();

b=(int)stack.pop();

stack.push(a*b);

break;

case'/':

b=(int)stack.pop();

a=(int)stack.pop();

stack.push((int)a/b);

break;

default:

//该字符是数字

stack.push(c-'0');

}

}

return stack.pop();

}

public BinaryTree create(String s){

//构造二叉树结点(递归)

int i=0,pos=0,len=0;

String l="",r="";

BinaryTree node=new BinaryTree();

len=s.length();

if(len==0) return null;

if(len==1){

//递归边界

node.data=s.charAt(0);

return node;

}

//去括号

while((pos=s.indexOf(")"))!=-1){

i=pos;

while((s.charAt(i)!='(')&&(i>0)) i--;

String sub=s.substring(i+1,pos);//括号中的表达式

porder="";

postorder(create(sub));//得到后缀表达式

int sum=calc(porder);//计算后缀表达式的值,替换原来括号中的表达式

s=s.substring(0,i)+String.valueOf(sum)+s.substring(pos+1);

len=s.length();//重新计算s的长度

}

//从后往前扫描得到的第一个优先级最低的运算符号的位置

pos=-1;

for(i=len-1;i>0;i--){

char c=s.charAt(i);

if((c=='+')||(c=='-')){

pos=i;

break;

}

else if(((c=='*')||(c=='/'))&&(pos==-1)) pos=i;

}

//在pos位置将s分为左右两部分,递归构造左右两个部分的二叉树

l=s.substring(0,pos);

r=s.substring(pos+1);

node.data=s.charAt(pos);

node.left=create(l);

node.right=create(r);

return node;

}

public static void main(String args[]) throws Exception{

BufferedReader reader=new BufferedReader(new InputStreamReader(System.in));

String s=reader.readLine();

Calculator c=new Calculator();

BinaryTree bt=c.create(s);

c.postorder(bt);

System.out.println(c.calc(c.porder));

}

}

好了,文章到此结束,希望可以帮助到大家。

aipt免费自动生成工具?小米11怎么用ai生成视频c语言程序设计pdf,c程序设计第五版电子书