C语言:多功能计算器
好家伙,这个东西有点折磨
这是一个多功能计算器
#include<stdio.h>
#include<math.h>
#include<windows.h>
void first();/*二元一次方程*/
void second();//一元二次方程//
void third();//矩阵的相加//
void fourth();//矩阵的相减//
void fifth();//矩阵的相乘//
void sixth();//三角函数运算//
void seventh();//阶乘的运算// int main()
{ while(1)
{
int a;
printf("\n");
printf("********多功能科学计算器*********\n");
printf("*\t1.二元一次方程求解\t*\n");
printf("*\t2.一元二次方程求解\t*\n");
printf("*\t3.矩阵的相加\t\t*\n");
printf("*\t4.矩阵的相减\t\t*\n");
printf("*\t5.矩阵的相乘\t\t*\n");
printf("*\t6.三角函数运算\t\t*\n");
printf("*\t7.阶乘的运算\t\t*\n");
printf("*\t0.重启程序\t\t*\n");
printf("****输入对应数字实现对应功能*****\n\n");
printf("请输入:");
scanf("%d",&a); if(a==0)
{
break;
}
switch(a)
{
case 1:
first();
break; case 2:
second();
break;
case 3:
third();
break;
case 4:
fourth();
break;
case 5:
fifth();
break;
case 6:
sixth();
break;
case 7:
seventh();
break;
}
system("pause");
system("cls");
} return 0;
}
void first()/*二元一次方程*/
{
double a,b,c,d,n,m,x,y;
printf("公式为ax+by=m cx+dy=n\n");
printf("请依次输入a,b,m,c,d,n\n");
scanf("%lf%lf%lf%lf%lf%lf",&a,&b,&m,&c,&d,&n);
if(a*d-b*c==0)
{
printf("该方程无解\n");
}
else
{
x=(d*m-n*b)/(a*d-b*c);
y=(a*n-c*m)/(a*d-b*c);
printf("x=%f,y=%f",x,y);
}
} void second()//一元二次方程//
{
double a,b,c,x1,x2 ;
printf("公式为ax*x+bx+c=0\n");
printf("请依次输入a,b,c\n");
scanf("%lf%lf%lf",&a,&b,&c);
if(b*b-4*a*c>=0)
{
x1=(-b+sqrt(b*b-4*a*c))/(2*a);
x2=(-b-sqrt(b*b-4*a*c))/(2*a);
if(x1==x2){
printf("该方程仅有一解x=%f\n",x1);
}
else
printf("x1=%f,x2=%f\n",x1,x2);
}
else
{
printf("该方程无解\n");
}
} void third()//矩阵的相加
{
int a[100][100],b[100][100],c[100][100];
int d,e,f,h,j,k;
printf("请输入第一个矩阵行数和列数;\n");
scanf("%d%d",&d,&e);
printf("请输入矩阵中的数字:\n");
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&a[f][h]); }
}
printf("请输入第二个矩阵行数和列数.\n");
scanf("%d%d",&j,&k);
printf("请输入矩阵中的数字:\n");
for(f=1;f<=j;f++)
{
for(h=1;h<=k;h++)
{
printf("请输入第%d行第%d列的数字",f,h); scanf("%d",&b[f][h]);
}
}
if(d==j&&e==k)//矩阵中只有行数于列数相同时候才能运算
{
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
c[f][h]=a[f][h]+b[f][h];
printf("%4d",c[f][h]);
}
printf("\n");
}
}
else
{
printf("该输入的矩阵无法相加,因为输入矩阵的行数与列数不同。\n");
}
} void fourth()//矩阵的相减//
{
int a[100][100],b[100][100],c[100][100];
int d,e,f,h,j,k;
printf("请输入第一个矩阵行数和列数;\n");
scanf("%d%d",&d,&e);
printf("请输入矩阵中的数字:\n");
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&a[f][h]);
}
}
printf("请输入第二个矩阵行数和列数.\n");
scanf("%d%d",&j,&k);
printf("请输入矩阵中的数字:\n");
for(f=1;f<=j;f++)
{
for(h=1;h<=k;h++)
{
printf("请输入第%d行第%d列的数字",f,h); scanf("%d",&b[f][h]);
}
}
if(d==j&&e==k)//矩阵中只有行数于列数相同时候才能运算
{
for(f=0;f<d;f++)
{
for(h=0;h<e;h++)
{
c[f][h]=a[f][h]-b[f][h];
printf("%4d",c[f][h]);
}
printf("\n");
}
}
else
{
printf("该输入的矩阵无法相减,因为输入矩阵的行数与列数不同。\n");
} } void fifth()//矩阵的相乘//
{
int a[100][100],b[100][100];
int d,e,f,h,j,k,t;
double sum;
double c[100][100];
printf("请输入第一个矩阵行数和列数;\n");
scanf("%d%d",&d,&e);
printf("请输入矩阵中的数字:\n");
for(f=0;f<d;f++)
{
for(h=0;h<e;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&a[f][h]);
}
}
printf("请输入第二个矩阵行数和列数.\n");
scanf("%d%d",&j,&k);
printf("请输入矩阵中的数字:\n");
for(f=0;f<j;f++)
{
for(h=0;h<k;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&b[f][h]);
}
}
if(e==j)//矩阵相乘只有在左边矩阵的列数等于右边矩阵的行数时才能相乘
{
for(f=0;f<d;f++)
{ for(h=0;h<k;h++)
{
sum=0;
for(t=0;t<e;t++)
{
sum+=a[f][t]*b[t][h];
}
c[f][h]=sum;
}
printf("\n");
}
for(f=0;f<d;f++)
{ for(h=0;h<e;h++)
{
printf("%f",c[f][h]);
}
printf("\n");
}
}
else
{
printf("该输入的矩阵无法相乘,因为输入左边的矩阵的列数不等于右边矩阵的行数。\n");
} } void sixth() //三角函数的运算
{
double n,s,c,t,pi=3.1415926;
printf("输入数n\n");
scanf("%lf",&n);
if(n==90)
{
s=sin(n*pi/180);
c=cos(n*pi/180);
t=tan(n*pi/180);
printf("sin%.f=%.2f\n",n,s);
printf("cos%.f=%.2f\n",n,c);
printf("tan%.f 不存在\n",n,t);
}
else
{
s=sin(n*pi/180);
c=cos(n*pi/180);
t=tan(n*pi/180);
printf("sin%.f=%.2f\n",n,s);
printf("cos%.f=%.2f\n",n,c);
printf("tan%.f=%.2f\n",n,t);
}
} void seventh()//阶乘的运算//
{
int a,b;
// unsigned long long sum=1;
long sum;
sum=1;
printf("请输入需要计算的阶乘:\n");
scanf("%d",&b);
for(a=1;a<=b;a++)
{
sum*=a;
}
printf("计算的结果为:%lld",sum);
}
1)概述或引言
开发环境为Visual C++
目前已实现的功能:
(1)解二元一次方程、一元二次方程
(2)进行矩阵相加、相减、相乘运算
(3)进行三角函数、阶乘运算
2)程序概要设计
程序流程:

其中包括的函数以及对应的功能:
|
函数名称 |
对应功能 |
|
first |
解二元一次方程 |
|
second |
解一元二次方程 |
|
third |
矩阵的相加 |
|
fourth |
矩阵的相减 |
|
fifth |
矩阵的相乘 |
|
sixth |
三角函数运算 |
|
seventh |
阶乘的运算 |
1.(first)函数解二元一次方程
开始时,按照” ax+by=m cx+dy=n”的格式依次输入:a,b,n,c,d,n;
核心算法部分:
(按照公式计算出x,y的值)
x=(d*m-n*b)/(a*d-b*c);
y=(a*n-c*m)/(a*d-b*c);
测试样例:
输入:1 3 4 1 1 2
输出:x=1.0000 y=1.0000

2.(second)函数 解一元二次方程
核心算法部分:
(按照公式计算出两解的值)
首先判断: b*b-4*a*c
x1=(-b+sqrt(b*b-4*a*c))/(2*a);
x2=(-b-sqrt(b*b-4*a*c))/(2*a);
测试样例:
输入:1 4 4
输出: 该方程仅有一解x=-2.000
如图:

3. (third)函数
解一元二次方程
核心算法部分:
(按照公式计算出矩阵的值)
3.1.矩阵输入
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&a[f][h]);
}
}
3.2.矩阵相加:
if(d==j&&e==k)//矩阵中只有行数于列数相同时候才能运算
{
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
c[f][h]=a[f][h]+b[f][h];
printf("%4d",c[f][h]);
}
printf("\n");
}
}
测试样例:
输入:2 2\n2\n2\n2\n2\n2 2\n 2\n2\n2\n2\n
输出: 4 4
4 4

4. (fourth)函数 解一元二次方程
核心算法部分:
(按照公式计算出矩阵的值)
4.1.矩阵输入:
for(f=1;f<=d;f++)
{
for(h=1;h<=e;h++)
{
printf("请输入第%d行第%d列的数字",f,h);
scanf("%d",&a[f][h]);
}
}
4.2.矩阵相减:
if(d==j&&e==k)//矩阵中只有行数于列数相同时候才能运算
{
for(f=0;f<d;f++)
{
for(h=0;h<e;h++)
{
c[f][h]=a[f][h]-b[f][h];
printf("%4d",c[f][h]);
}
printf("\n");
}
}
测试样例:
输入:2 2\n2\n2\n2\n2\n2 2\n 2\n2\n2\n2\n
输出: 0 0
0 0

5. (second)函数 矩阵的相乘
(有bug,在修复)
6. (sixth)函数 三角函数运算
核心算法部分:
(按照公式计算出 的值)
6.1.计算sin,cos,tan(输入值n为角度(如:90)):
s=sin(n*pi/180);
c=cos(n*pi/180);
t=tan(n*pi/180);
测试样例:
输入:90
输出: sin90=1.00
cos90=0.00
tan90 不存在

7. (seventh)函数 阶乘的运算
核心算法部分:
(按照公式计算出 的值)
7.1.阶乘计算(输入值为b):
for(a=1;a<=b;a++)
{
sum*=a;
}
测试样例:
输入:10
输出: 计算的结果为:3628800

矩阵相乘暂时还有bug,正在修复。
C语言:多功能计算器的更多相关文章
- 李洪强漫谈iOS开发[C语言-042]-简单计算器
李洪强漫谈iOS开发[C语言-042]-简单计算器
- iOS应用内语言切换功能
当我们的应用仅仅面向国内用户群,一般仅支持一种语言--中文就可以了.当面向国外用户时就需要进行国际化了,不仅仅是语言的转变,也可能包括设计风格,页面布局.交互效果的转变,如微信,微博,QQ这类应用都有 ...
- Android学习–Android app 语言切换功能
功能: app用户根据自己的语言喜好,设置app语言.语言设置只针对本app,并在下次启动应用时保留前一次启动设置. 更新语言: public static void changeAppLanguag ...
- C语言实现简易计算器(可作加减乘除)
C语言实现简易计算器(加减乘除) 计算器作为课设项目,已完成答辩,先将代码和思路(注释中)上传一篇博客 已增添.修改.整理至无错且可正常运行 虽使用了栈,但初学者可在初步了解栈和结构语法后理解代码 # ...
- C语言:多功能计算器程序说明书
好家伙,3000字终于写完了 一.题目:多功能科学计算器 二.内容: (1)概述或引言 开发环境为Visual C++ 目前已实现的功能: (1)解二元一次方程.一元二次方程 (2)进行矩阵相加.相减 ...
- C语言:多功能计算器 (矩阵相乘)
好家伙,实现矩阵相乘功能 代码如下: void fifth()//矩阵的相乘// { int a[100][100],b[100][100]; int d,e,f,h,j,k,t; double su ...
- C语言实现简单计算器小项目
昨天刚安装上devc++,半夜想着练练C语言吧 于是就看到实验楼有一个计算器的项目 之前做过一次,这次写的主要是思路 首先我们先从原理思考jia,实现简单的计算器就要具备加减乘除这些,看普通的计算器也 ...
- Android app应用多语言切换功能实现
最近在做一个多语言切换的功能,类似于微信的语言切换,搜了下资料基本上都是以下这种: 1. 实现的效果 和微信类似,在设置界面打开切换语言的界面,选择语言后重启 HomeActivity,语言切换完成, ...
- C语言,简单计算器【上】
由于工作需要最近在研究PHP扩展,无可避免的涉及到了C语言.从出了学校以后C语言在实际工作中还没有用到过,所以必须要先进行一点复习工作.个人认为对于熟悉一样东西说最好的方法是上手实践.于是便想起了当时 ...
随机推荐
- 『忘了再学』Shell流程控制 — 33、if条件判断语句(一)
目录 1.单分支if条件语句 2.双分支if条件语句 (1)示例1 (2)示例2 什么是流程控制? 普通理解:Shell编写的程序是顺序执行的,也就是说第一命令先执行,然后接着执行第二条命令,然后再下 ...
- go Cobra命令行工具入门
简介 Github:https://github.com/spf13/cobra Star:26.5K Cobra是一个用Go语言实现的命令行工具.并且现在正在被很多项目使用,例如:Kuberne ...
- SAP Context menu(菜单)
*&---------------------------------------------------------------------* *& Report RSDEMO_CO ...
- UiPath官网认证中文教程
RPA之家公众号:RPA之家 RPA之家官网:http://rpazj.com 斗鱼直播:http://www.douyu.com/rpazj UiPath中文社区QQ群:465630324 RPA& ...
- 周报?谁还写周报啊?不都用Python小工具: 发个周报邮件给老板就行还写周报啊?不都用Python小工具: 发个周报邮件给老板就行
缘起: 新跳槽到一家公司, 没想到第一个挑战居然是每周都要发周报. 告诉老板这周都干了些什么和下周准备干什么. 我记性不好, 常常忘事儿.所以很多时候周报都会忘记发送. 于是, 就决定写一个小工具好了 ...
- 所有人都说Python 简单易学,为何我觉得难?
来谈谈心 记得刚学Python的时候,几乎所有人都说Python 简单易学,而对于编程零基础,只掌握Word和Excel的人来说,感觉真的好难. 学习之前网上的教材看了,Python的书也看了,包括& ...
- linux中CentOS配置文件编辑错误撤回
未编辑状态下 U键 撤销 DD 快速删除
- 使用强大的DBPack处理分布式事务(PHP使用教程)
主流的分布式事务的处理方案 近些年,随着微服务的广泛使用,业务对系统的分布式事务处理能力的要求越来越高. 早期的基于XA协议的二阶段提交方案,将分布式事务的处理放在数据库驱动层,实现了对业务的无侵入, ...
- 关于'utf-8' codec can't decode byte 0xb9 in position 0: invalid start byte报错
今天在使用vscode编译程序时,启动Python服务出现以下错误: 通过网络查找资料可以得知,是由于个人用户名非英文而导致,但是网上并没有说清楚是哪里的名字,以至于很多人会以为是以下地方: 实际上真 ...
- 关于 Python 的 import
好久以前就被 Python 的相对与绝对导入所困扰.去年粗浅探究后自以为完全理解,近来又因 sys.path[0] 和 os.getcwd() 的不一致而刷新了认知... Python 官方文档 5. ...