当前位置: 首页 > article >正文

java实现真值表代码(不完善)恳求大佬指导

今天离散数学老师让我们尝试用编程来实现真值表,自己做了一个但是限制有点多,希望有大佬能指点一下。

Test类

import java.util.Scanner;

public class Test {
    public static void main(String[] args) {
        System.out.println("规则: 1,每个步骤必须有括号 2,输入的字母必须从a开始(例a,b,c,d)");
        System.out.println("输入命题公式吧");
        Scanner input = new Scanner(System.in);
        String str = input.nextLine();  //获取字符串
        char[] arr = new char[20];
        int[] arr2 = new int[30];
        int count = 0; //计数器
        int j = 0;
        for (int i = 0; i < str.length(); i++) {
            char a = str.charAt(i);
            if (Character.isLetter(a)){
                arr[j] = a;
                j++;
            }
        }
        for (int i = 0; i < j; i++) {
            char w = arr[i];
            arr2[w-'a']+=1;
        }
        for (int i = 0; i < arr2.length; i++) {
            if(arr2[i]!=0){
                count++;
                arr2[i]=0;
            }
        }
        System.out.println(count);
        boolean[] Boolean = new boolean[count];
        TruthTable truthTable = new TruthTable();
        truthTable.setArr(str);
        truthTable.create(Boolean,0);

    }


}

TruthTable

import java.util.ArrayDeque;
import java.util.Queue;
import java.util.Stack;

public class TruthTable {
    public String getArr() {
        return str;
    }

    public void setArr(String arr) {
        this.str = arr;
    }
    private String str;

    public void create(boolean[] Boolean,int index){
        if(Boolean.length==index){
            display(Boolean);
            Judge(Boolean,str);//这里--------
            System.out.println();
            //未打印
            return;
        }

        Boolean[index] = false;
        create(Boolean,index+1);

        Boolean[index] = true;
        create(Boolean,index+1);
    }

    public void display(boolean[] Boolean){
        for (int i = 0; i < Boolean.length; i++) {
            if(Boolean[i] == true){
                System.out.print(1 + " ");
            }
            else {
                System.out.print(0 + " ");
            }
        }
    }

    Stack<Character> stack = new Stack<>();//括号
    Stack<Boolean> stack2 = new Stack<>();//010101
    //∨ ∧ ↔ → ¬
    //char az =
    public void Judge(boolean[] Boolean,String str){
        //((p→((¬p→q)∧r))∨q)
        stack.clear();
        stack2.clear();
        boolean w=false;
        boolean a=false;
        boolean b=false;
        int j = 0;
        for (int i = 0; i < str.length(); i++) {
            char c = str.charAt(i);
            if(c=='('){
                stack.push(c);
            }
            if(Character.isLetter(c)){
                if(c=='a'){
                    stack2.push(Boolean[0]);
                }
                else if(c=='b'){
                    stack2.push(Boolean[1]);
                } else if (c=='c') {
                    stack2.push(Boolean[2]);
                } else if (c=='d') {
                    stack2.push(Boolean[3]);
                }else if (c=='e') {
                    stack2.push(Boolean[4]);
                } else if (c=='f') {
                    stack2.push(Boolean[5]);
                }
                else if (c=='g') {
                    stack2.push(Boolean[6]);
                }
                else if (c=='h') {
                    stack2.push(Boolean[7]);
                }
                else if (c=='i') {
                    stack2.push(Boolean[8]);
                } else if (c=='j') {
                    stack2.push(Boolean[9]);
                }
                //_________________________________________________这块
            }
            if(c=='∨' || c=='∧' || c=='↔' || c=='→' || c=='¬'){
                stack.push(c);
            }
            if(c==')'){
                while (stack.peek()!='('){
                    if (!stack2.isEmpty()){
                        a = stack2.pop();//先出的在右边
                    }
                    if (!stack2.isEmpty()){
                        b = stack2.pop();
                    }
                    if(stack.peek()=='∧'){
                        if(a==true && b==true){
                            System.out.print("    " + 1);
                            w = true;
                        } else{
                            System.out.print("    " + 0);
                            w = false;
                        }
                        stack2.push(w);
                        stack.pop();
                    }
                    if (stack.peek()=='∨'){
                        if(a==true || b==true){
                            System.out.print("    " + 1);
                            w = true;
                        } else{
                            System.out.print("    " + 0);
                            w = false;
                        }
                        stack2.push(w);
                        stack.pop();
                    }
                    if (stack.peek()=='↔'){
                        if(a==b){
                            System.out.print("    " + 1);
                            w = true;
                        } else{
                            System.out.print("    " + 0);
                            w= false;
                        }
                        stack2.push(w);
                        stack.pop();
                    }
                    if(stack.peek()=='→'){
                        if(b==false){
                            System.out.print("    " + 1);
                            w = true;
                        }
                        else if(b==true && a==true){
                            System.out.print("    " + 1);
                            w = true;
                        }
                        else if(b==true && a==false){
                            System.out.print("    " + 0);
                            w = false;
                        }
                        //System.out.print(b + " " + a);
                        stack2.push(w);
                        stack.pop();
                    }
                    if(stack.peek()=='¬'){
                        stack2.push(b);
                        boolean t = !a;
                        System.out.print("    " + (t ? 1 : 0));
                        stack2.push(t);
                        stack.pop();
                    }
                }
                stack.pop();
            }
        }
    }
}


http://www.kler.cn/a/308626.html

相关文章:

  • INQUIRE:一个包含五百万张自然世界图像,涵盖10,000个不同物种的专为专家级文本到图像检索任务设计的新型基准数据集。
  • ArkTs简单入门案例:简单的图片切换应用界面
  • 2024年11月13日
  • 2024版本IDEA创建Sprintboot项目下载依赖缓慢
  • MySQL45讲 第二十讲 幻读是什么,幻读有什么问题?
  • vue3+element-plus==> el-form输入响应式失效踩坑!!!!!!!!!!
  • 利用AI驱动智能BI数据可视化-深度评测Amazon Quicksight(三)
  • 使用 Visual Studio Code 配置 C++ 开发环境的详细指南
  • sqlx1.3.4版本的问题
  • 【MySQL】Windows下重启MySQL服务时,报错:服务名无效
  • 语言模型与人类反馈的深度融合:Chain of Hindsight技术
  • 主流日志框架Logback与Log4j2
  • 【TS】TypeScript配置详解【三】
  • HarmonyOS axios 拦截器处理token 及异常
  • js的书写位置和css的书写位置的区别?为什么要这样写?
  • dedecms(四种webshell姿势)
  • 微服务之间远程调用实现思路
  • pdf文件转图片,base64或保存到本地
  • django 通过地址访问本地文件
  • Java原生HttpURLConnection实现Get、Post、Put和Delete请求完整工具类分享
  • 高级I/O知识分享【5种IO模型 || select || poll】
  • c++概念
  • windows启动jar指定jdk路径
  • 网页本地存储
  • 【C++】list 模拟实现
  • Vscode运行Python无法导入自己编写的包的解决方法