找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3186|回复: 1
打印 上一主题 下一主题
收起左侧

简单计算器c语言源程序

[复制链接]
跳转到指定楼层
楼主
ID:70976 发表于 2014-12-25 13:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include<reg51.h>
  2. #include<math.h>
  3. #define uint unsigned int
  4. #define uchar unsigned char
  5. uchar code tab[]={0xee,0xed,0xeb,0xe7,
  6.       0xde,0xdd,0xdb,0xd7,
  7.       0xbe,0xbd,0xbb,0xb7,
  8.       0x7e,0x7d,0x7b,0x77,};   //0~f键位码表


  9. uchar code tab1[]={0x88,0Xbe,0Xc4,0X94,0Xb2,0X91,0X81,0Xbc,
  10.        0X80,0X90,0xa0,0x83,0xc9,0x86,0xc1,0xe1,0xff};  //0~f字型码表

  11. void delay(uchar x)          //毫秒级延时函数
  12. {
  13. uchar y;            
  14. for(;x>0;x--)
  15.   for(y=110;y>0;y--);
  16. }


  17. scanf()    //按键处理函数   
  18. {
  19. uchar temp,temp1,i;   
  20. P0=0xf0;        //给P0口赋值为oxf0,用于列扫描
  21. if(P0!=0xf0)   //判别是否有键按下
  22. {
  23.   delay(2);  
  24.   if(P0!=0xf0)    //再次判别是否有键按下
  25.   {
  26.    temp1=P0;   //P0值赋给temp1
  27.    P0=0x0f;   //P0值赋为0x0f,用于行扫描
  28.    temp=temp1|P0; //将行列扫描值合并,赋给temp
  29.   }

  30. switch(temp)
  31. {
  32.   case 0xee:i=1; break;
  33.   case 0xed:i=2; break;
  34.   case 0xeb:i=3; break;
  35.   case 0xe7:i=4; break;
  36.   case 0xde:i=5; break;
  37.   case 0xdd:i=6; break;
  38.   case 0xdb:i=7; break;
  39.   case 0xd7:i=8; break;
  40.   case 0xbe:i=9; break;
  41.   case 0xbd:i=0; break;
  42.   case 0xbb:i=10; break;
  43.   case 0xb7:i=11; break;
  44.   case 0x7e:i=12; break;
  45.   case 0x7d:i=13; break;
  46.   case 0x7b:i=14; break;
  47.   case 0x77:i=15; break;  
  48. }
  49. }
  50.   else return 16;
  51.   return i;
  52. }  



  53. void display(uint temp)     //显示函数
  54. {
  55. uchar i;
  56. uchar z[6];
  57. z[0]=16;
  58. z[1]=temp/10000;
  59. z[2]=temp%10000/1000;
  60. z[3]=temp%1000/100;
  61. z[4]=temp%100/10;
  62. z[5]=temp%10;


  63. for(i=0;i<6;i++)
  64. {   
  65.   SBUF=tab1[z[ i]];   // 根据键位值找到键码值,将键码值赋给串行口发送寄存器
  66.   while(!TI);   //判断串口数据发送是否完毕
  67.   TI=0;         //串口数据发送完毕标志清0
  68. }


  69. }



  70. E(uchar n)
  71. {
  72. uint  t=1;
  73. for(;n>0;n--)
  74. t=t*10;
  75. return t;
  76. }





  77. void main(void)     //主函数
  78. {




  79. uint tem,tem1;

  80. uchar x,y,fh,j,k=0;
  81. uchar zhi[6];
  82. uchar zhi1[6];

  83. while(1)
  84. {


  85.   if(x<5&&!k)
  86.   { if(scanf()<10)
  87.   {
  88.    delay(5);
  89.    if(scanf()<10)
  90.    {
  91.      if(x==0){zhi[0]=scanf();while(scanf()!=16);}
  92.    
  93.      if(x==1){zhi[1]=scanf();while(scanf()!=16);}

  94.      if(x==2){zhi[2]=scanf();while(scanf()!=16);}

  95.      if(x==3){zhi[3]=scanf();while(scanf()!=16);}

  96.      if(x==4){zhi[4]=scanf();while(scanf()!=16);}   


  97.      x++;            
  98.      tem=0;

  99.     for(y=0;y<x;y++)
  100.     {
  101.      tem=tem+zhi[y]*E(x-1-y);
  102.     }

  103.      display(tem);
  104.      
  105.      
  106.     }

  107.    }
  108.    
  109.   }
  110.   


  111.   
  112. if(scanf()>11&&scanf()<16)
  113. {
  114.   delay(2);
  115.   if(scanf()>9&&scanf()<16)
  116.   {
  117.    
  118.    fh=scanf();
  119.    while(scanf()!=16);
  120.    k=1;
  121.   }
  122. }


  123.   

  124. if(j<5&&k)
  125.   { if(scanf()<10)
  126.   {
  127.    delay(2);
  128.    if(scanf()<10)
  129.    {
  130.      if(j==0){zhi1[0]=scanf();while(scanf()!=16);}
  131.    
  132.      if(j==1){zhi1[1]=scanf();while(scanf()!=16);}

  133.      if(j==2){zhi1[2]=scanf();while(scanf()!=16);}

  134.      if(j==3){zhi1[3]=scanf();while(scanf()!=16);}

  135.      if(j==4){zhi1[4]=scanf();while(scanf()!=16);}

  136.      j++;            
  137.      tem1=0;

  138.     for(y=0;y<j;y++)
  139.     {
  140.      tem1=tem1+zhi1[y]*E(j-1-y);
  141.     }

  142.      display(tem1);
  143.      
  144.      
  145.     }

  146.    }
  147.    
  148.   }


  149. if(scanf()==11)
  150. {
  151. delay(2);
  152. if(scanf()==11)
  153. { while(scanf()==11);
  154.   if(fh==12)tem=tem+tem1;
  155.   if(fh==13)tem=tem-tem1;
  156.   if(fh==14)tem=tem*tem1;
  157.   if(fh==15)tem=tem/tem1;
  158.   display(tem);
  159.   j=0;
  160.   
  161. }
  162. }
  163.   
  164.   

  165. }
  166. }
复制代码




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:76106 发表于 2015-4-4 12:08 | 只看该作者
非常好 谢谢啦
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表