C语言问题,利用堆栈实现四则运算,谢谢高手帮我编写出来
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言问题,利用堆栈实现四则运算,谢谢高手帮我编写出来相关的知识,希望对你有一定的参考价值。
如题高手编写高分感谢
参考技术A 我就喜欢害人:)#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#defineERR-1
#defineMAX100/*定义堆栈的大小*/
intstack[MAX];/*用一维数组定义堆栈*/
inttop=0;/*定义堆栈指示*/
intpush(inti)/*存储运算数,入栈操作*/
if(top<MAX)
stack[++top]=i;/*堆栈仍有空间,栈顶指示上移一个位置*/
return0;
else
printf("Thestackisfull");
returnERR;
intpop()/*取出运算数,出栈操作*/
intvar;/*定义待返回的栈顶元素*/
if(top!=NULL)/*堆栈中仍有元素*/
var=stack[top--];/*堆栈指示下移一个位置*/
returnvar;/*返回栈顶元素*/
else
printf("Thestackisempty!\n");
returnERR;
voidmain()
intm,n;
charl;
inta,b,c;
intk;
do
printf("\tAriothmaticOperatesimulator\n");/*给出提示信息*/
printf("\n\tPleaseinputfirstnumber:");/*输入第一个运算数*/
scanf("%d",&m);
push(m);/*第一个运算数入栈*/
printf("\n\tPleaseinputsecondnumber:");/*输入第二个运算数*/
scanf("%d",&n);
push(n);/*第二个运算数入栈*/
printf("\n\tChooseoperator(+/-/*//):");
l=getche();/*输入运算符*/
switch(l)/*判断运算符,转而执行相应代码*/
case'+':
b=pop();
a=pop();
c=a+b;
printf("\n\n\tTheresultis%d\n",c);
printf("\n");
break;
case'-':
b=pop();
a=pop();
c=a-b;
printf("\n\n\tTheresultis%d\n",c);
printf("\n");
break;
case'*':
b=pop();
a=pop();
c=a*b;
printf("\n\n\tTheresultis%d\n",c);
printf("\n");
break;
case'/':
b=pop();
a=pop();
c=a/b;
printf("\n\n\tTheresultis%d\n",c);
printf("\n");
break;
printf("\tContinue?(y/n):");/*提示用户是否结束程序*/
l=getche();
if(l=='n')
exit(0);
while(1);
用C语言写一个程序实现以下功能
本人C学的不太好,各位高手帮帮忙,谢谢咯!
要求如下:
主界面
*******************************
******* 系统 ******************
*****请选择以下你要的操作******
1.求阶乘倒数之和.(用递归法)
2.将一个十进制数转换成R进制数(利用函数调用)
3.求3个数的最大公约数和最小公倍数(利用函数调用)
4.把一个整数插入到按由小到大排列的数列中,插入后仍然保持由小到大的顺序排列.(利用数组和指针来做)
5.求N阶方阵的转置矩阵(利用多维数组或指针作函数参数)
如果有完整的并且通过调试有用的话,可以追加分数!
大家帮帮忙咯!我急用,谢谢!
/*
*功能函数
*/
/*求阶乘倒数之和(用递归法)*/
factorial();
long factr(int n);
/*
*以下函数实现将一个十进制数转换成R进制数(利用函数调用)
*五个函数
*/
decimalchange();
unsigned int check(char *s,unsigned int m);
void strtonum(char* str,unsigned int *p,unsigned int m);
unsigned long mto10(int *p,unsigned int mlen,unsigned int m);
void tenton(unsigned long l10,int *p,int n,unsigned int nlen);
/*多个数的最大公约数和最小公倍数*/
gCDAddLCM();/*主函数*/
int gcd(int a, int b); /* 最大公约数 */
int cmd(int a, int b); /* 最小公倍数 */
int multipleGCD(int arr[], int len); /* 多个数的最大公约数 */
int multipleCMD(int arr[], int len); /* 多个数的最小公倍数*/
/*把一个整数插入到按由小到大排列的数列中
*插入后仍然保持由小到大的顺序排列
*/
insertCosmos();
/*求N阶方阵的转置矩阵*/
transposedMatrix();
int main()
int c;
scanf("%d",&c);
while(c!=0)
printf("**********************************************************\n");
printf("************************* 系统 ***************************\n");
printf(" 主菜单(请选择以下你要的操作) \n");
printf(" 1 求阶乘倒数之和(用递归法) \n");
printf(" 2 将一个十进制数转换成R进制数(利用函数调用) \n");
printf(" 3 求3个数的最大公约数和最小公倍数(利用函数调用) \n");
printf(" 4 把一个整数插入到按由小到大排列的数列中,
插入后仍然保持由小到大的顺序排列.(利用数组和指针来做) \n");
printf(" 5 求N阶方阵的转置矩阵 \n");
printf(" 0 退出 \n");
printf(" 输入选择 (1--5,0表示结束): ");
switch(c)
case 1:factorial();break;
case 2:decimalchange();break;
case 3:gCDAddLCM();break;
case 4:insertCosmos();break;
case 5:transposedMatrix();break;
default:;
return 0;
//main end 参考技术A 问那么多问题?
我刚刚写了一个进制转换的,给你了。
---------------vc6.0测试通过---
-------- 我的可以支持到16进制数的转换------------
----------要更多的进制表示,你可以在switch语句中自己加就可以了---------------
#include <stdio.h>
#include <stdlib.h>
void main()
int nNum,Rad,i=0,Residue;
int Store[50];
printf("请输入一个任意整数:");
scanf("%d",&nNum);
printf("\n请输入一个合法的表示进制的基数[2,16]:");
scanf("%d",&Rad);
if(Rad<=1)
exit(-1);
printf("\n转换后的结果是:");
while(nNum>=Rad)
Residue=nNum%Rad;//0
nNum/=Rad;//1
Store[i]=Residue;//0
++i;
Store[i]=nNum;
for(;i>=0;--i)
switch(Store[i])
case 0:
printf("0");
break;
case 1:
printf("1");
break;
case 2:
printf("2");
break;
case 3:
printf("3");
break;
case 4:
printf("4");
break;
case 5:
printf("5");
break;
case 6:
printf("6");
break;
case 7:
printf("7");
break;
case 8:
printf("8");
break;
case 9:
printf("9");
break;
case 10:
printf("A");
break;
case 11:
printf("B");
break;
case 12:
printf("C");
break;
case 13:
printf("D");
break;
case 14:
printf("E");
break;
case 15:
printf("F");
break;
printf("\n");
参考技术B main()
int c;
printf("请选择以下你要的操作");
printf("1.求阶乘倒数之和");
printf("2.将一个十进制数转换成R进制数");
printf("3.求3个数的最大公约数和最小公倍数");
printf("4.把一个整数插入到按由小到大排列的数列中,插入后仍然保持由小到大的顺序排列");
printf("5.求N阶方阵的转置矩阵");
scanf("%d",&c);
switch(c)
case:1 //写自定义函数。1
case:2 //写自定义函数。2
break;
case:3 //写自定义函数。3
break;
case:4 //写自定义函数。4
break;
case:5 //写自定义函数。5
break;
default:
printf("你输入的是错误的选择");
参考技术C 眼熟 不过
我好象不会 啊
对不起了本回答被提问者采纳 参考技术D 应该不难……
以上是关于C语言问题,利用堆栈实现四则运算,谢谢高手帮我编写出来的主要内容,如果未能解决你的问题,请参考以下文章
C语言 四则运算 各位C语言高手帮忙做下这题!!谢谢谢谢谢谢