首页 > 编程语言 >制作计算器——训练程序思维

制作计算器——训练程序思维

时间:2024-08-10 12:54:27浏览次数:12  
标签:思维 数字 训练 List Add 计算器 vals figure

自己做的计算器

主要的逻辑如下:
用两个集合,每个数字对应一个符号,先收集数字和符号,然后再处理乘除法,再处理加减法,最后得出计算的数字;(此方法不一定是最优方法,因为没有收集网络上的资料,是自己想出来的解决方案)

 按钮 “=” 的逻辑如下:

 var val = show.Text;
 var vals = val.Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);

 //案例: 1 + 2 * 3 / 4 - 5;
 //分析后如下:
 //数字:  1 2 3 4 5
 //        | | | |
 //符号:  + * / -

 List<decimal> figure = new List<decimal>();//数字
 List<string> flag = new List<string>();//符号
 for (int i = 0; i < vals.Length; i = i + 2)
 {
     if (i  == vals.Length - 1)//是最后一个数字
     {
         break;
     }
     figure.Add(decimal.Parse(vals[i]));
     flag.Add(vals[i + 1]);
 }
 figure.Add(decimal.Parse(vals[vals.Length - 1]));//最后一个数字

 //处理乘法 和 除法
 for (int i = 0; i <= figure.Count-1 -1; i++)
 {
     var flag_temp = flag[i];
     if (flag_temp == "x")
     {
         figure[i] = figure[i] * figure[i + 1];
         if ( (i + 1) != figure.Count- 1)//不是最后一个数字
         {                        
             flag.RemoveAt(i);
         }
         figure.RemoveAt(i + 1);
         i--;

         continue;
     }
     if (flag_temp == "/")
     {
         figure[i] = figure[i] / figure[i + 1];                    
         if ((i + 1) != figure.Count - 1)//不是最后一个数字
         {   
             flag.RemoveAt(i);
         }
         figure.RemoveAt(i + 1);
         i--;

         continue;
     }
 }

 decimal all = figure[0];
 for (int i = 0; i <= figure.Count -2 ; i++)
 {
     //all = all figure[i];
     if (flag[i] == "+")
     {
         all = all + figure[i+ 1];
     }
     else
     {
         all = all - figure[i+1];
     }
 }

 show.Text = show.Text + "\r\n" + "="  + "\r\n" + all.ToString();

 IsCalculate = true;

  

源码分享:

通过百度网盘分享的文件:计算器

链接:https://pan.baidu.com/s/1-xqbopR21srQG4SakHZnYQ 

提取码:sfqf

 

 

制作不易,欢迎点赞分享加关注,欢迎赞赏!

标签:思维,数字,训练,List,Add,计算器,vals,figure
From: https://www.cnblogs.com/SHa-Jazy/p/18352185

相关文章

  • 2024牛客暑期多校训练营2
    A.FloorTiles恶心构造,本来构造的方法没有错,因为不小心修改了第一块砖的位置,导致一直过不去,没注意,倒了思路:先把最多曲线的构造出来,就是类似于BAB......
  • 「代码随想录算法训练营」第三十四天 | 动态规划 part7
    198.打家劫舍题目链接:https://leetcode.cn/problems/house-robber/文章讲解:https://programmercarl.com/0198.打家劫舍.html题目难度:中等视频讲解:https://www.bilibili.com/video/BV1Te411N7SX题目状态:有点思路但不全。思路:这次的dp[i]数组表示在到第i个房间中时最多的......
  • 做题小结 dp训练4
    第一个我按dp找结果是个二分我还想半天这怎么dp不过这题目也很有意义首先我一直以为vector的low或者upp下标只能用distance求现在看来是错的不要再写auto迭代器写法用int就行减初始指针就行然后二分的话思路也很好先存进去然后在跑t的时候先开一个指针然后对于......
  • 做题小结 dp训练3
    第一个这道题主要思考到一个不可以连续两步以及最大往左移动5位就像背包一样所以我们开个二维的dp数组表示 for(intj=1;j<=z;j++){ if(i+j*2<=k+1&&i-1>=1){ dp[i][j]=max(dp[i][j-1]+a[i-1]+a[i],max(dp[i][j],dp[i-1][j]+a[i])); ......
  • *算法训练(leetcode)第四十七天 | 并查集理论基础、107. 寻找存在的路径
    刷题记录*并查集理论基础107.寻找存在的路径*并查集理论基础讲解107.寻找存在的路径题目地址直接套模板。结点编号从1开始,因此定义father数组时需要n+1个空间,否则会越界。时间复杂度:O(......
  • SSD训练细节
    sampling·pyimportrandomimporttorchimporttorch.nnasnnfromtorch.autogradimportVariablefromtorch.autogradimportFunctionfrombboximportbboxIOU__all__=["buildPredBoxes","sampleEzDetect"]defbuildPredBoxes(config)......
  • 2024牛客暑期多校训练营8 I Haitang and Ranking 题解
    乱搞看到\(n=1e5\),时限3s,存在修改操作,很自然的想到根号分治。考虑按照时间分治。对每\(B\)个交换统一处理,\(B\)个交换最多有\(2B\)个元素改变状态,剩下都不变。那么只要对这\(2B\)元素内,暴力枚举,剩下的元素构建数据结构实现二维数点,平面内区间最值。因为\(a,b\)是不......
  • 做题小结 DP训练
    第一个开了个二维数组表示删除不删除然后去重了下如果前后相差为1的话,就可以进行删除的思考此时i要删除的话i-1必须要不删除如果i不删除的话存一个前面的max即可这边注意下可能有重复的数如果前后相差不为1的话我们就可以肆无忌惮怎么搞都行此题结束第二题这题和......
  • 自闭症儿童康复训练后能否顺利迈进小学之门
    在当今社会,自闭症儿童的教育和发展备受关注。经过康复训练的自闭症儿童能否顺利进入小学,成为了众多家长和教育工作者关心的重要问题。自闭症儿童在经过系统的康复训练后,其状况会得到不同程度的改善。但能否上小学,不能简单地一概而论,而需要综合考虑多个方面的因素。康复训练的......
  • 代码随想录算法训练营day08|344.反转字符串,541.反转字符串II,卡码网:54.替换数字
    344.反转字符串题目链接:https://leetcode.cn/problems/reverse-string/description/我的代码:classSolution{public:voidreverseString(vector<char>&s){for(inti=0;i<s.size()/2;i++){chartemp=s[i];s[i]=......