Java Applet シューティングゲーム「carac」ソースコード ― 2022年08月12日 05:29
/* carac */
import java.applet.*;
import java.awt.*;
class Tek {
int xk, yk;
int idkx, idky;
boolean ari, ido;
}//class Tek end
public class carac extends Applet implements Runnable {
int stno;
int tidorit, tidoxh, tidoyh;
boolean idouari;
int gcau;
int slmati;
int tokten, ttenzo, zanki;
int mojtak, shotido, bakido;
Font f1;
boolean mkon, hkon, xkon;
boolean gamran;
Thread kicker = null;
Image offs;
Graphics grf;
int tekmax; final int tekmaxmax = 25;
int bakmax; final int bakmaxmax = 10;
int shotmax; final int shotmaxmax = 5;
int spbakmax; final int spbakmaxmax = 5;
Tek tek[];
Tek bak[];
Tek shot[];
Tek spbak[];
int idox, idoy, idcau, idcaumax;
int idkox, idkoy;
int jibx, jiby, jibido;
boolean shotmati, spbakmati;
int spbakrit;
final int haba = 300;
final int taka = 200;
final int yoyu = 15;
Button butn1, butn2, butn3;
Label label1,label2;
public void init() {
slmati = 40;
mojtak = 12; shotido = 3; bakido = 2;
f1 = new Font("TimesRoman", Font.PLAIN, mojtak);
mkon = false; hkon = false; xkon = false;
gamran = false;
offs = createImage(haba, taka+yoyu);
grf = offs.getGraphics();
grf.setFont(f1);
setLayout(null);
resize(500,500);
//butn1 = new Button("stage1"); add(butn1);
//butn2 = new Button("stage2"); add(butn2);
//butn3 = new Button("stage3"); add(butn3);
butn1 = new Button("stage1"); add(butn1); butn1.setBounds(4,4,50,22);
butn2 = new Button("stage2"); add(butn2); butn2.setBounds(55,4,50,22);
butn2.disable();
butn3 = new Button("stage3"); add(butn3); butn3.setBounds(110,4,50,22);
butn3.disable();
label1 = new Label("Move:'Right' or 'Left'Key" );
label1.setBounds(4, 30, 150, 22); label1.setBackground(Color.white); add(label1);
label2 = new Label("Shoot:'x'Key");
label2.setBounds(4, 50, 150, 22); label2.setBackground(Color.white); add(label2);
shotmati = false;
spbakmati = false;
clia();
tek = new Tek[tekmaxmax];
bak = new Tek[bakmaxmax];
shot = new Tek[shotmaxmax];
spbak = new Tek[spbakmaxmax];
stno = 1;
}//init end
void tek1set() {
int kj;
stno = 1;
jibx = 145; jiby = taka - 2; jibido = 2;
tekmax = 11; /* 0..11 */
idox = 1; idoy = (mojtak / 1); idcau = 0; idcaumax = 100;
idkox = idox; idkoy = idoy;
gcau = 0;
tokten = 0; ttenzo = 100; zanki = 5;
kj = haba - haba / 2;
shotmax = 0; shotset();
bakmax = 1; bakset();
spbakrit = 80; spbakmax = 4; spbakset(); /* dummy */
idouari = false;
tidorit = 50; tidoxh = 100; tidoyh = 500; /* dummy */
for(int i = 0; i <= tekmax; i++) tek[i] = new Tek();
tek[0].xk = kj; tek[0].yk = 2 + mojtak*3;
tek[1].xk = kj - 1*mojtak*2; tek[1].yk = 2 + mojtak*3;
tek[2].xk = kj - 2*mojtak*2; tek[2].yk = 2 + mojtak*3;
tek[3].xk = kj - 3*mojtak*2; tek[3].yk = 2 + mojtak*3;
tek[4].xk = kj - 4*mojtak*2; tek[4].yk = 2 + mojtak*3;
kj -= mojtak;
tek[5].xk = kj; tek[5].yk = 2 + mojtak*2;
tek[6].xk = kj - 1*mojtak*2; tek[6].yk = 2 + mojtak*2;
tek[7].xk = kj - 2*mojtak*2; tek[7].yk = 2 + mojtak*2;
tek[8].xk = kj - 3*mojtak*2; tek[8].yk = 2 + mojtak*2;
kj -= mojtak;
tek[9].xk = kj; tek[9].yk = 2 + mojtak;
tek[10].xk = kj - 1*mojtak*2; tek[10].yk = 2 + mojtak;
tek[11].xk = kj - 2*mojtak*2; tek[11].yk = 2 + mojtak;
for(int i = 0; i <= tekmax; i++) {
tek[i].ari = true; tek[i].ido = false;
tek[i].idkx = idox; tek[i].idky = idoy;
}//for end
}//tek1set end
void tek2set() {
int kj;
stno = 2;
jibx = 145; jiby = taka - 2; jibido = 2;
tekmax = 17;
idox = 1; idoy = (mojtak / 1); idcau = 0; idcaumax = 100;
idkox = idox; idkoy = idoy;
gcau = 0;
tokten = 0; ttenzo = 100; zanki = 5;
kj = haba - haba / 2;
shotmax = 1; shotset();
bakmax = 3; bakset();
spbakrit = 80; spbakmax = 4; spbakset(); /* dummy */
idouari = true;
tidorit = 50; tidoxh = 100; tidoyh = 500;
for(int i = 0; i <= tekmax; i++) tek[i] = new Tek();
tek[0].xk = kj; tek[0].yk = 2 + mojtak*4;
tek[1].xk = kj - 1*mojtak*2; tek[1].yk = 2 + mojtak*4;
tek[2].xk = kj - 2*mojtak*2; tek[2].yk = 2 + mojtak*4;
tek[3].xk = kj - 3*mojtak*2; tek[3].yk = 2 + mojtak*4;
tek[4].xk = kj - 4*mojtak*2; tek[4].yk = 2 + mojtak*4;
tek[5].xk = kj - 5*mojtak*2; tek[5].yk = 2 + mojtak*4;
kj -= mojtak;
tek[6].xk = kj; tek[6].yk = 2 + mojtak*3;
tek[7].xk = kj - 1*mojtak*2; tek[7].yk = 2 + mojtak*3;
tek[8].xk = kj - 2*mojtak*2; tek[8].yk = 2 + mojtak*3;
tek[9].xk = kj - 3*mojtak*2; tek[9].yk = 2 + mojtak*3;
tek[10].xk = kj - 4*mojtak*2; tek[10].yk = 2 + mojtak*3;
kj -= mojtak;
tek[11].xk = kj; tek[11].yk = 2 + mojtak*2;
tek[12].xk = kj - 1*mojtak*2; tek[12].yk = 2 + mojtak*2;
tek[13].xk = kj - 2*mojtak*2; tek[13].yk = 2 + mojtak*2;
tek[14].xk = kj - 3*mojtak*2; tek[14].yk = 2 + mojtak*2;
kj -= mojtak;
tek[15].xk = kj; tek[15].yk = 2 + mojtak;
tek[16].xk = kj - 1*mojtak*2; tek[16].yk = 2 + mojtak;
tek[17].xk = kj - 2*mojtak*2; tek[17].yk = 2 + mojtak;
for(int i = 0; i <= tekmax; i++) {
tek[i].ari = true; tek[i].ido = false;
tek[i].idkx = idox; tek[i].idky = idoy;
}//for end
}//tek2set end
void tek3set() {
int kj;
stno = 3;
jibx = 145; jiby = taka - 2; jibido = 2;
tekmax = 24;
idox = 1; idoy = (mojtak / 1); idcau = 0; idcaumax = 100;
idkox = idox; idkoy = idoy;
gcau = 0;
tokten = 0; ttenzo = 100; zanki = 5;
kj = haba - haba / 2;
shotmax = 2; shotset();
bakmax = 9; bakset();
spbakrit = 20; spbakmax = 4; spbakset();
idouari = true;
tidorit = 20; tidoxh = 100; tidoyh = 500;
for(int i = 0; i <= tekmax; i++) tek[i] = new Tek();
tek[0].xk = kj; tek[0].yk = 2 + mojtak*5;
tek[1].xk = kj - 1*mojtak*2; tek[1].yk = 2 + mojtak*5;
tek[2].xk = kj - 2*mojtak*2; tek[2].yk = 2 + mojtak*5;
tek[3].xk = kj - 3*mojtak*2; tek[3].yk = 2 + mojtak*5;
tek[4].xk = kj - 4*mojtak*2; tek[4].yk = 2 + mojtak*5;
tek[5].xk = kj - 5*mojtak*2; tek[5].yk = 2 + mojtak*5;
tek[6].xk = kj - 6*mojtak*2; tek[6].yk = 2 + mojtak*5;
kj -= mojtak;
tek[7].xk = kj; tek[7].yk = 2 + mojtak*4;
tek[8].xk = kj - 1*mojtak*2; tek[8].yk = 2 + mojtak*4;
tek[9].xk = kj - 2*mojtak*2; tek[9].yk = 2 + mojtak*4;
tek[10].xk = kj - 3*mojtak*2; tek[10].yk = 2 + mojtak*4;
tek[11].xk = kj - 4*mojtak*2; tek[11].yk = 2 + mojtak*4;
tek[12].xk = kj - 5*mojtak*2; tek[12].yk = 2 + mojtak*4;
kj -= mojtak;
tek[13].xk = kj; tek[13].yk = 2 + mojtak*3;
tek[14].xk = kj - 1*mojtak*2; tek[14].yk = 2 + mojtak*3;
tek[15].xk = kj - 2*mojtak*2; tek[15].yk = 2 + mojtak*3;
tek[16].xk = kj - 3*mojtak*2; tek[16].yk = 2 + mojtak*3;
tek[17].xk = kj - 4*mojtak*2; tek[17].yk = 2 + mojtak*3;
kj -= mojtak;
tek[18].xk = kj; tek[18].yk = 2 + mojtak*2;
tek[19].xk = kj - 1*mojtak*2; tek[19].yk = 2 + mojtak*2;
tek[20].xk = kj - 2*mojtak*2; tek[20].yk = 2 + mojtak*2;
tek[21].xk = kj - 3*mojtak*2; tek[21].yk = 2 + mojtak*2;
kj -= mojtak;
tek[22].xk = kj; tek[22].yk = 2 + mojtak;
tek[23].xk = kj - 1*mojtak*2; tek[23].yk = 2 + mojtak;
tek[24].xk = kj - 2*mojtak*2; tek[24].yk = 2 + mojtak;
for(int i = 0; i <= tekmax; i++) {
tek[i].ari = true; tek[i].ido = false;
tek[i].idkx = idox; tek[i].idky = idoy;
}//for end
}//tek3set end
void shotset() {
for(int i = 0; i <= shotmax; i++) {
shot[i] = new Tek(); shot[i].ari = false;
}//for end
}//shotset end
void bakset() {
for(int i = 0; i <= bakmax; i++) {
bak[i] = new Tek(); bak[i].ari = false;
}//for end
}//bakset end
void spbakset() {
for(int i = 0; i <= spbakmax; i++) {
spbak[i] = new Tek(); spbak[i].ari = false;
}//for end
}//spbakset end
void jibegak() {
grf.setColor(Color.cyan);
grf.drawString("A", jibx, jiby);
}//jibegak end
void tekdanido() {
int dmy1;
dmy1 = 0;
idcau++;
if(idcau >= idcaumax) {idcau = 0; idox = -idox; dmy1 = idoy;}
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari && (! tek[i].ido))
tek[i].xk += idox; tek[i].yk += dmy1;
}//for end
}//tekdanido end
void tekkoidouon() {
int dmy1;
switch(gcau) {
case 0: case 1: case 2: case 5: case 6: case 7:
case 10: case 11: case 16: case 17:
case 21: case 22: case 23: case 24:
dmy1 = (int)(Math.random() * tidorit);
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari && (! tek[i].ido) && dmy1 == 0) {
tek[i].ido = true;
return;
}//if end
}//for end
break;
}//switch end
}//tekkoidouon end
void tekkoidou() {
int dmy1;
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari && tek[i].ido) {
if(stno == 3) {
if(tek[i].xk > jibx) tek[i].idkx = -idkox;
else tek[i].idkx = idkox;
}//if end
else {
dmy1 = (int)(Math.random() * tidoxh); /* */
if(dmy1 == 0) tek[i].idkx = -tek[i].idkx;
}//else end
dmy1 = (int)(Math.random() * tidoyh); /* */
if(dmy1 == 0) tek[i].idky = -tek[i].idky;
tek[i].xk += tek[i].idkx;
if(tek[i].xk <= 0) tek[i].xk = haba;
else if(tek[i].xk >= haba) tek[i].xk = 0;
tek[i].yk += (tek[i].idky / 5);
if(tek[i].yk <= 0) tek[i].yk = taka + yoyu;
else if(tek[i].yk >= (taka + yoyu)) tek[i].yk = 0;
}//if end
}//for end
}//tekkoidou end
boolean tekhit() {
boolean dmy1 = false;
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari) {
if((tek[i].xk - (mojtak / 2)) <= jibx &&
jibx <= (tek[i].xk + (mojtak / 2)) &&
(tek[i].yk - (mojtak / 2)) <= jiby &&
jiby <= (tek[i].yk + (mojtak / 2))) {
grf.setColor(Color.red);
grf.drawString("X", tek[i].xk, tek[i].yk);
dmy1 = true;
tek[i].ari = false; zanki -= 1;
}//if end
}//if end
}//for end
if(dmy1) return true; else return false;
}//tekhit end
void tekegak() {
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari) {
grf.setColor(Color.green);
grf.drawString("T", tek[i].xk, tek[i].yk);
}//if end
}//for end
}//tekegak end
void shoton() {
for(int i = 0; i <= shotmax; i++) {
if((! shot[i].ari) && (! shotmati)) {
shot[i].xk = jibx; shot[i].yk = jiby - mojtak; shot[i].ari = true;
shotmati = true;
}//if end
}//for end
}//shoton end
void shotegak() {
shotmati = false;
for(int k = 0; k <= shotmax; k++) {
if(shot[k].ari) {
grf.setColor(Color.yellow);
grf.drawString("^", shot[k].xk, shot[k].yk);
shot[k].yk -= shotido;
if(shot[k].yk >= (taka - (mojtak * 2))) shotmati = true;
if(shot[k].yk <= 0) shot[k].ari = false;
}//if end
}//for end
}//shotegak end
void shothit() {
for(int k = 0; k <= shotmax; k++) {
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari && shot[k].ari) {
if((tek[i].xk - (mojtak / 2)) <= shot[k].xk &&
shot[k].xk <= (tek[i].xk + (mojtak / 2)) &&
(tek[i].yk - (mojtak / 2)) <= shot[k].yk &&
shot[k].yk <= (tek[i].yk + (mojtak / 2))) {
grf.setColor(Color.red);
grf.drawString("X", tek[i].xk, tek[i].yk);
tek[i].ari = false; tokten += ttenzo; gcau += 1;
shot[k].ari = false;
}//if end
}//if end
}//for end
}//for end
}//shothit end
void bakon() {
int dmy1;
for(int j = 0; j <= bakmax; j++) {
dmy1 = (int)(Math.random() * (tekmax + 1));
for(int i = 0; i <= tekmax; i++) {
if(dmy1 == i) {
if(tek[i].ari && (! bak[j].ari)) {
bak[j].xk = tek[i].xk; bak[j].yk = tek[i].yk + mojtak;
bak[j].ari = true;
}//if end
}//if end
}//for end
}//for end
}//bakon end
void bakegak() {
for(int i = 0; i <= bakmax; i++) {
if(bak[i].ari) {
grf.setColor(Color.magenta);
grf.drawString("|", bak[i].xk, bak[i].yk);
bak[i].yk += bakido;
if(bak[i].yk >= taka) bak[i].ari = false;
}//if end
}//for end
}//bakegak end
boolean bakhit() {
boolean dmy1 = false;
for(int i = 0; i <= bakmax; i++) {
if(bak[i].ari) {
if((bak[i].xk - (mojtak / 2)) <= jibx &&
jibx <= (bak[i].xk + (mojtak / 2)) &&
(bak[i].yk - (mojtak / 2)) <= jiby &&
jiby <= (bak[i].yk + (mojtak / 2))) {
grf.setColor(Color.red);
grf.drawString("X", bak[i].xk, bak[i].yk);
dmy1 = true;
bak[i].ari = false; zanki -= 1;
}//if end
}//if end
}//for end
if(dmy1) return true; else return false;
}//bakhit end
void spbakon() {
int dmy1;
for(int j = 0; j <= spbakmax; j++) {
for(int i = 0; i <= tekmax; i++) {
if(tek[i].ari && tek[i].ido) {
dmy1 = (int)(Math.random() * spbakrit);
if(dmy1 == 0) {
if(! spbak[j].ari) {
spbak[j].xk = tek[i].xk; spbak[j].yk = tek[i].yk + mojtak;
spbak[j].ari = true;
}//if end
}//if end
}//if end
}//for end
}//for end
}//spbakon end
void spbakegak() {
for(int i = 0; i <= spbakmax; i++) {
if(spbak[i].ari) {
grf.setColor(Color.magenta);
grf.drawString("*", spbak[i].xk, spbak[i].yk);
spbak[i].yk += bakido * 2;
if(spbak[i].yk >= taka) spbak[i].ari = false;
}//if end
}//for end
}//spbakegak end
boolean spbakhit() {
boolean dmy1 = false;
for(int i = 0; i <= spbakmax; i++) {
if(spbak[i].ari) {
if((spbak[i].xk - (mojtak / 2)) <= jibx &&
jibx <= (spbak[i].xk + (mojtak / 2)) &&
(spbak[i].yk - (mojtak / 2)) <= jiby &&
jiby <= (spbak[i].yk + (mojtak / 2))) {
grf.setColor(Color.red);
grf.drawString("X", spbak[i].xk, spbak[i].yk);
dmy1 = true;
spbak[i].ari = false; zanki -= 1;
}//if end
}//if end
}//for end
if(dmy1) return true; else return false;
}//spbakhit end
public void run() {
while(kicker != null) {
if(gamran) {
clia();
kisyori();
if((! bakhit()) && (! tekhit()) && (! spbakhit())) jibegak();
bakon(); bakegak();
if(stno == 3) {spbakon(); spbakegak();}
shotegak(); shothit();
if(idouari) {tekkoidouon(); tekkoidou();}
tekdanido();
tekegak();
toktenkak();
gamova();
cliames();
repaint();
}//if end
try {
Thread.sleep(slmati);
} catch(InterruptedException e) {}
}//while end
kicker = null;
}//run end
void toktenkak() {
grf.setColor(Color.blue);
grf.drawString("ten= "+tokten, 5, taka+yoyu-2);
grf.setColor(Color.cyan);
grf.drawString("zan= "+zanki, haba-50, taka+yoyu-2);
}//toktenkak end
void cliames() {
int cau = 0;
for(int i = 0; i <= tekmax; i++) if(! tek[i].ari) cau++;
if(cau >= tekmax + 1) {
grf.setColor(Color.magenta);
grf.drawString("Omedeto !!", 100, taka + yoyu - 2);
jiby -= 1; if(jiby <= (mojtak + 2)) {
jiby = mojtak + 2;
gamran = false;
switch(stno){
case 1: butn1.enable(); butn2.enable(); stno = 2; break;
case 2: butn1.enable(); butn2.enable(); butn3.enable(); stno = 3; break;
}
}//if jib idou end
}//if end
}//cliames end
void gamova() {
if(zanki <= 0) {
grf.setColor(Color.blue);
grf.drawString("Zannen !", 100, taka + yoyu - 2);
gamran = false;
}//if end
}//gamova end
public boolean action(Event e, Object o) {
String lab = o.toString();
if(e.target instanceof Button) {
if(lab.equals("stage1")) {tek1set(); stno = 1; gamran = true;}
if(lab.equals("stage2")) {tek2set(); stno = 2; gamran = true;}
if(lab.equals("stage3")) {tek3set(); stno = 3; gamran = true;}
}//if end
return true;
}//action end
public boolean handleEvent(Event e) {
if(e.id == Event.KEY_ACTION) {
if(e.key == e.RIGHT) mkon = true;
if(e.key == e.LEFT) hkon = true;
return true;
}//if end
if(e.id == Event.KEY_ACTION_RELEASE) {
if(e.key == e.RIGHT) mkon = false;
if(e.key == e.LEFT) hkon = false;
return true;
}//if end
if(e.id == Event.KEY_PRESS) {
if(e.key == 'x') xkon = true;
return true;
}//if end
if(e.id == Event.KEY_RELEASE) {
if(e.key == 'x') xkon = false;
return true;
}//if end
return super.handleEvent(e);
}//handleEvent end
void kisyori() {
if(mkon && jibx <= (haba - (mojtak / 2))) jibx += jibido;
if(hkon && jibx >= 0) jibx -= jibido;
if(xkon) shoton();
}//kisyori end
public void start() {
if(kicker == null) { kicker = new Thread(this); kicker.start(); }
}//start end
public void stop() {
if(kicker != null) { kicker.stop(); kicker = null; }
}//stop end
public void update(Graphics g) {
paint(g);
}//update end
void clia() {
grf.setColor(Color.black);
grf.fillRect(0, 0, haba, taka+yoyu);
grf.setColor(Color.blue);
grf.drawLine(0, taka, haba, taka);
}//clia end
public void paint(Graphics g) {
g.drawImage(offs, 4, 80, this);
}//paint end
public static void main(String[] args) {
// TODO code application logic here
new MyFrame("carac", new carac(), 500, 500);
}
}
javaアプレット→フレーム 変換用 MyFrame ソースコード ― 2022年08月12日 05:31
import java.applet.Applet;
import java.awt.Frame;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
class MyFrame extends Frame {
Applet myApplet;
MyFrame(String title, Applet applet, int width, int height) {
super(title);
myApplet = applet;
add("Center", myApplet);
pack();
myApplet.init();
setSize(width, height);
show();
myApplet.start();
addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
myApplet.stop();
myApplet.destroy();
dispose();
System.exit(0);
}
});
}
}
Java 逆ポーランド記法とスタック操作による四則計算機 ソースコード ― 2022年08月12日 11:31
/** *********************************** */
/* 逆ポーランド記法とスタック操作による四則計算機 */
/** *********************************** */
import java.awt.*;
import java.util.Deque;
import java.util.ArrayDeque;
import java.util.HashMap;
import java.util.Map;
public class algopol extends java.applet.Applet {
TextField txtPorand, txtAns;
Button btnKeisan;
TextField txtMoto;
Button btnHenkan;
public void start() {
txtMoto = new TextField(20);
btnHenkan = new Button("変換");
txtPorand = new TextField(20);
txtAns = new TextField(20);
btnKeisan = new Button("計算");
txtMoto.setText("元の計算式");
txtPorand.setText("逆ポーランド式");
txtAns.setText("計算結果");
add(txtMoto);
add(btnHenkan);
add(txtPorand);
add(btnKeisan);
add(txtAns);
}
public boolean action(Event evt, Object what) {
if (evt.target == btnHenkan) {
txtPorand.setText(toRPN(txtMoto.getText()));
}
if (evt.target == btnKeisan) {
//r=res(stf.getText()); /* 書かれた式を計算 */
//rf.setText(String.valueOf(r)); /* 結果を表示 */
txtAns.setText(parseRPN(txtPorand.getText()));
return true;
}
return false;
}
public static void main(String[] args) {
// TODO code application logic here
new MyFrame("逆ポーランド式 四則計算機", new algopol(), 500, 500);
}
/** <h1>逆ポーランド記法(Reverse Polish Notation)[=後置記法:postfix notation]を計算する</h1>
* <p>
* スペースで区切った "10 20 30 * +" のような形式。連続した空白は1つ分の空白として処理される。
* <br>四則演算(+, -, *, /)と括弧のみ。</p>
*
* @param rpn : 逆ポーランド記法での計算式
* @return<b>int</b> : 計算された値
*/
public static final String parseRPN(final String rpn) {
final Deque<String> stack = new ArrayDeque<String>();
double aa, bb;
String s = rpn.replaceAll("\\s+", " "); //連続した空白文字をスペース1つ分に置き換える
final String[] arr = s.trim().split(" ");
for (String e : arr) {
if ('0' <= e.charAt(0) && e.charAt(0) <= '9') { //数字
stack.push(e);
} else {
aa = Double.parseDouble(stack.pop());
bb = Double.parseDouble(stack.pop());
if (e.equals("*")) {
stack.push(String.valueOf(bb * aa));
} else if (e.equals("/")) {
stack.push(String.valueOf(bb / aa)); // div/0 でInfinityとなる
} else if (e.equals("+")) {
stack.push(String.valueOf(bb + aa));
} else if (e.equals("-")) {
stack.push(String.valueOf(bb - aa));
}
}
}
return stack.pop();
}
/**
* 逆ポーランド記法用の演算子優先順位
*/
@SuppressWarnings("serial")
static final Map<Character, Integer> rpnRank = new HashMap<Character, Integer>() {
{//ブロックで記述
put('(', 4); //※数値が高いほど、優先順位が高いとする
put('#', 3); //オペランド(数値)[キーはダミー]
put('*', 2);
put('/', 2);
put('+', 1);
put('-', 1);
put(')', 0);
}
};
/** <h1>式を逆ポーランド記法(Reverse Polish Notation)[=後置記法:postfix notation]に変換する</h1>
* <p>
* スペースを含まない "10+20*30-40+50" のような式。空白文字は全て除去される。
* <br>四則演算(+, -, *, /)と括弧のみ。除算は整数除算(小数点以下切り捨て)。</p>
*
* @param expression : 変換する式
* @return<b>String</b> : 逆ポーランド記法に変換された式
*/
public static final String toRPN(final String expression) {
final Deque<Character> stack = new ArrayDeque<Character>();
String s = expression.replaceAll("\\s+", ""); //空白文字を取り除く
s = "(" + s + ")"; //末尾に")"を付けることで、最後にスタックを吐き出させる
final int len = s.length();
String ans = ""; //戻値用(RPN式)バッファ
String tmp = ""; //数字用バッファ
for (int i = 0; i < len; i++) {
char c = s.charAt(i);
if ('0' <= c && c <= '9') {
tmp += c; //数字1文字ずつのため
} else {
if (!tmp.equals("")) {
if (ans.length() > 0) {
ans += " ";
}
ans += tmp;
tmp = "";
}
while (!stack.isEmpty() && rpnRank.get(stack.peek()) >= rpnRank.get(c) && stack.peek() != '(') {
if (ans.length() > 0) {
ans += " ";
}
ans += stack.pop();
}
if (c == ')') {
stack.pop(); //'('
} else {
stack.push(c);
}
}
}
return ans;
}
}
Delphi 逆ポーランド記法 四則計算機 関数部ソースコード ― 2022年08月12日 17:53
unit ReversePolish;
interface
uses
SysUtils, Classes;
procedure Infix2RP(StIn, StOut: TStringList);
function CalcRPN(St: TStringList): Currency;
implementation
//----------------------------------------------------------------------------
function Priority(S: String): Integer;
begin
S := Trim(S);
if S = '=' then
Result := 0
else if S = ')' then
Result := 1
else if S = '+' then
Result := 2
else if S = '-' then
Result := 2
else if S = '*' then
Result := 3
else if S = '/' then
Result := 3
else if S = '(' then
Result := 4
else
Result := 5;
end;
//----------------------------------------------------------------------------
// 変換処理
// StIn : 中置記法 A = ( B - C ) / D + E * F
// StOut: 逆ポーランド記法 A B C - D / E F * + =
//----------------------------------------------------------------------------
procedure Infix2RP(StIn, StOut: TStringList);
var
StStack: TStringList;
i: Integer;
Token: String;
begin
StStack := TStringList.Create;
try
for i := 0 to StIn.Count - 1 do
begin
Token := Trim(StIn[i]);
if Length(Token) = 0 then
Continue;
while (StStack.Count <> 0) and
(StStack[StStack.Count - 1] <> '(') and
(Priority(Token) <= Priority(StStack[StStack.Count - 1])) do
begin
if (StStack[StStack.Count - 1] <> '(') and (StStack[StStack.Count - 1]
<> ')') then
StOut.Add(StStack[StStack.Count - 1]);
StStack.Delete(StStack.Count - 1);
end;
if Token <> ')' then
begin
StStack.Add(Token);
end
else
begin
StStack.Delete(StStack.Count - 1);
end;
end;
while (StStack.Count <> 0) do
begin
if (StStack[StStack.Count - 1] <> '(') and (StStack[StStack.Count - 1]
<> ')') then
StOut.Add(StStack[StStack.Count - 1]);
StStack.Delete(StStack.Count - 1);
end;
finally
StStack.Free;
end;
end;
//----------------------------------------------------------------------------
// 逆ポーランド記法の計算式を計算
//----------------------------------------------------------------------------
function CalcRPN(St: TStringList): Currency;
var
StStack: TStringList;
i: Integer;
wkC, op1, op2: Currency;
begin
StStack := TStringList.Create;
try
for i := 0 to St.Count - 1 do
begin
try
wkC := StrToFloat(St[i]);
StStack.Add(St[i]);
except
begin
op2 := StrToFloat(StStack[StStack.Count - 1]);
StStack.Delete(StStack.Count - 1);
op1 := StrToFloat(StStack[StStack.Count - 1]);
StStack.Delete(StStack.Count - 1);
if St[i] = '/' then
wkC := op1 / op2
else if St[i] = '*' then
wkC := op1 * op2
else if St[i] = '-' then
wkC := op1 - op2
else if St[i] = '+' then
wkC := op1 + op2;
StStack.Add(FloatToStr(wkC));
end;
end;
end;
Result := StrToFloat(StStack[StStack.Count - 1]);
finally
StStack.Free;
end;
end;
end.
Delphi 逆ポーランド記法 四則計算機 本体ソースコード ― 2022年08月12日 17:55
unit Unit1;
interface
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls;
type
TForm1 = class(TForm)
Memo1: TMemo;
Memo2: TMemo;
Button1: TButton;
Button2: TButton;
Edit1: TEdit;
Memo3: TMemo;
edMoto: TEdit;
btnMotoHen: TButton;
btnPora: TButton;
edPora: TEdit;
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure btnMotoHenClick(Sender: TObject);
procedure btnPoraClick(Sender: TObject);
private
{ Private 宣言 }
public
{ Public 宣言 }
end;
var
Form1: TForm1;
implementation
uses
ReversePolish;
{$R *.dfm}
procedure TForm1.btnMotoHenClick(Sender: TObject);
var
i,j,iBan,naga:integer;
sdmy,sdmyS:string;
begin
memo1.Lines.Clear;
naga := Length(edMoto.Text);
sdmyS := '';
j := 0;
for iBan := 1 to naga do begin
sdmy := Copy(edMoto.Text,iBan,1);
//showmessage('naga='+intToStr(naga)+','+'iBan='+intToStr(iBan)+','+sdmy+'END');
if sdmy = ' ' then begin
memo1.Lines.Add(sdmyS);
sdmyS := '';
j := 0;
end;
if sdmy <> ' ' then begin
inc(j);
insert(sdmy,sdmyS,j);
//showmessage('naga='+intToStr(naga)+','+'iBan='+intToStr(iBan)+','+sdmy+',j='+intToStr(j)+','+sdmyS);
end;
end;
memo1.Lines.Add(sdmyS);
end;
procedure TForm1.btnPoraClick(Sender: TObject);
var
sdmy,sdmyS:string;
i,j,gyou:integer;
begin
edPora.Text := '';
gyou := memo2.Lines.Count;
//showmessage('gyou='+inttostr(gyou));
j := -1;
sdmyS := '';
for i := 1 to gyou do begin
j := j + 2;
sdmy := memo2.Lines[i-1]+' ';
edPora.Text := edPora.text + sdmy;
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin //変換
Memo2.Lines.Clear;
Infix2RP(TStringList(Memo1.Lines), TStringList(Memo2.Lines));
end;
procedure TForm1.Button2Click(Sender: TObject);
begin //計算
Edit1.Text := '';
Edit1.Text := FloatToStr(CalcRPN(TStringList(Memo2.Lines)));
end;
end.