C# 计算器 计算部分(未详测)

本文介绍了一种用于计算和解析复杂数学表达式的算法,包括获取表达式计算结果的方法及通过加减乘除表达式获取数值的过程。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;


namespace ImpExcel
{
    public class Calculater
    {
        /// <summary>
        ///  获取表达式计算结果的值
        /// </summary>
        /// <param name="Exp"> 例:(1 + (2 - 6))* 4 / 6-((1+2)*(3-4))注:-1要用0-1表表示</param>
        /// <returns>double 类型的一个值</returns>
        public double GetExpVal(string Exp)
        {
            //(())()
            return Convert.ToDouble(GetOutExp(Exp));
        }
        private string GetOutExp(string Exp)
        {
            int index = Exp.LastIndexOf("(") + 1;
            if (index == 0)
            {
                return GetInnerExpVal(Exp).ToString();
            }
            int endIndex = Exp.IndexOf(")", index);
            string innerExp = Exp.Substring(index, endIndex - index);
            double innerval = GetInnerExpVal(innerExp);
            string replacewitval;
            if (innerval < 0)
            {
                replacewitval = "0" + innerval;
            }
            else
            {
                replacewitval = innerval + "";
            }


            Exp = Exp.Replace("(" + innerExp + ")", replacewitval);
            return GetOutExp(Exp);
        }
        /// <summary>
        /// 通过加减乘除表达式获取一个值
        /// </summary>
        /// <param name="Exp">1+2-3*4</param>
        /// <returns>值</returns>
        public double GetInnerExpVal(string Exp)
        {
            Stack<string> opStack = new Stack<string>();
            Stack<double> numStack = new Stack<double>();
            string pattern = @"(-)|(/)|(\+)|(\*)";
            string[] parts = Regex.Split(Exp, pattern);
            Queue<string> queue = new Queue<string>(parts);
            while (true)
            {
                if (queue.Count == 0)
                {
                    break;
                }
                string part = queue.Dequeue();
                double d = 0.0;
                try
                {
                    d = Convert.ToDouble(part.Trim());
                    numStack.Push(d);
                }
                catch
                {
                    if (part == "+" || part == "-")
                    {
                        opStack.Push(part);
                    }
                    else
                    {
                        double d1 = numStack.Pop();
                        double d2 = Convert.ToDouble(queue.Dequeue().Trim());
                        if (part == "*")
                        {
                            numStack.Push(d1 * d2);
                        }
                        else if (part == "/")
                        {
                            numStack.Push(d1 / d2);
                        }
                    }


                }
            }
            while (true)
            {
                if (numStack.Count == 1)
                {
                    break;
                }
                double d1 = numStack.Pop();
                double d2 = numStack.Pop();
                string op = opStack.Pop();
                if (op == "+")
                {
                    numStack.Push(d1 + d2);
                }
                else if (op == "-")
                {
                    numStack.Push(d2 - d1);
                }
            }
            return numStack.Pop();
        }
    }
}
基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究(Matlab代码实现)内容概要:本文围绕“基于可靠性评估序贯蒙特卡洛模拟法的配电网可靠性评估研究”,介绍了利用Matlab代码实现配电网可靠性的仿真分析方法。重点采用序贯蒙特卡洛模拟法对配电网进行长时间段的状态抽样与统计,通过模拟系统元件的故障与修复过程,评估配电网的关键可靠性指标,如系统停电频率、停电持续时间、负荷点可靠性等。该方法能够有效处理复杂网络结构与设备时序特性,提升评估精度,适用于含分布式电源、电动汽车等新型负荷接入的现代配电网。文中提供了完整的Matlab实现代码与案例分析,便于复现和扩展应用。; 适合人群:具备电力系统基础知识和Matlab编程能力的高校研究生、科研人员及电力行业技术人员,尤其适合从事配电网规划、运行与可靠性分析相关工作的人员; 使用场景及目标:①掌握序贯蒙特卡洛模拟法在电力系统可靠性评估中的基本原理与实现流程;②学习如何通过Matlab构建配电网仿真模型并进行状态转移模拟;③应用于含新能源接入的复杂配电网可靠性定量评估与优化设计; 阅读建议:建议结合文中提供的Matlab代码逐段调试运行,理解状态抽样、故障判断、修复逻辑及指标统计的具体实现方式,同时可扩展至不同网络结构或加入更多不确定性因素进行深化研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值