简单c语言课程设计

c语言课程设计问题该怎么做?

这个程序设计其实很简单的。

(1)这个要求最简单,用prinf语句直接输出相关信息即可。

(2)这个要求也容易,用for语句实现循环,循环体用sanf语句,加system(“pause”);语句,就可以实现键盘输入回车确定。接受键盘数据的变量要用数组,这个关系到后面的统计排序。用if(a【i】==0) break; 即输入0回车就退出循环。

(3)通过for语句对数组a进行遍历,统计之前输入序号的个数(其实在(2)中就可以统计)保存另一个数组b中。然后对这个数组b的数据进行降序排列。

(4)这个要求只是考查C语言创建、读取和写入文件操作的要求而已,熟悉一下相关代码使用方法即可,分别写入数组a、数组b就行了。

C语言课程设计 贪吃蛇

2.1程序功能介绍

贪吃蛇游戏是一个经典小游戏,一条蛇在封闭围墙里,围墙里随机出现一个食物,通过按键盘四个光标键控制蛇向上下左右四个方向移动,蛇头撞倒食物,则食物被吃掉,蛇身体长一节,同时记10分,接着又出现食物,等待蛇来吃,如果蛇在移动中撞到墙或身体交叉蛇头撞倒自己身体游戏结束。

2.2程序整体设计说明

一个游戏要有开始部分,运行部分,结束部分(实际上开始部分与运行部分是一体的)。

2.2.1设计思路

这个程序的关键是表示蛇的图形以及蛇的移动。用一个小矩形表示蛇的一节身体,身体每长一节,增加一个矩形块,蛇头用两节表示。移动时必须从蛇头开始,所以蛇不能向相反方向移动,也就是蛇尾不能改作蛇头。如果不按任何键,蛇自行在当前方向上前移,当游戏者按了有效的方向键后,蛇头朝着指定的方向移动,一步移动一节身体,所以当按了有效的方向键后,先确定蛇头的位置,然后蛇身体随着蛇头移动,图形的实现是从蛇头的新位置开始画出蛇,这时由于没有庆平的原因,原来蛇的位置和新蛇的位置差一个单位,所以看起来社会多一节身体,所以将蛇的最后一节用背景色覆盖。食物的出现和消失也是画矩形块和覆盖矩形块

2.2.2数据结构设计及用法说明

开始部分:

游戏是运行在图形模式下的,所以第一步一定是初始化图形模式,接着要有开始的界面,就像书有封面一样,我设置了一个游戏的标题画面,除了游戏标题画面我还设置了一个欢迎画面。标题画面以后,还要为游戏的运行部分作初始化,包括绘制游戏运行时的背景,对游戏某些重 要变量的初始化。

运行部分:

作为游戏的核心部分,这里包括的函数比较多,也就是模块比较多,首先让我模拟一下贪吃蛇的游戏模式:某个世界上突然出现一条蛇,它很短,它的运动神经异常,它没法停止自己的多动症在它的世界里就只有食物,它很饿,也很贪吃;同样在不明原因的情况下,食物从天而降,可惜的是没有落到嘴边;饥饿的主人公,不管它有没有毒,也不问食物的来历,径直向食物爬去;它吃到食物啦,它超出想象的同化能力让食物很快的成为自己身体的一部分,它的身子变长啦。当它吃到第一颗食物时,上帝有给它第二颗,于是它吃了第二颗,于是又变长了,于是又有第三颗……它的身子是一直的加长,它不管自己过长身体的麻烦——转身不便,继续吃下去,现在它是直接把巴张大,好让食物有个绿色通道。但是在某天的下午,它咬到了自己,它才想起自己是一条毒蛇,于是晕死过去(不是毒死);又或者它往食物冲锋的时候,它失去控制,撞到了墙上。

第一轮循环:第一步,出现食物;第二步,蛇不停运动;第三步,检查蛇是撞到自己或墙壁;由第四步起游戏有两条支线(A、B):

A :第四步,蛇没有碰到自己或墙壁,蛇继续前进,绘制蛇的动作;第五步,判断蛇是否吃到食物,如果蛇吃到食物,身子变长,原来的食物消失;第六步,让玩家输入控制指令,让蛇在下一轮循环的第二步改变运动方向;第七步,第二轮循环的第一步,重复第一轮的步骤;

B:第四步,蛇碰到自己或墙壁,终止游戏。

结束部分:

游戏结束时,显示“GAME OVER”,已经是约定俗成的规律了,我的游戏也不例外。除了游戏结束画面外,我还设置了一个游戏退出画面,“善始善终”嘛。

有了上述的大致划分,我把整个程序划分成(13+2)个模块(其实就是函数)

2.2.3程序结构(流程图)

图2.1流程图

依据所需要处理的任务要求,规划输入数据和输出结果,决定存放数据的数据结构。

C语言中数据结构集中体现在数据类型上,因此在进行C语言程序设计时,应统筹规划程序中所使用的变量,数组,指针等,以及它们的类型等。这点是很重要的,如果在此期间选择不合适的变量或者数组,将来修改就十分困难。

现在分析一下贪吃蛇游戏中的元素,继而得出与它们对应的在程序中的描述:

蛇:

基本描述:长度,颜色,位置。

对应数据与数据类型:长度—虽然可以用坐标表示,但是这样的话,运算量将很大,所以换算成较大的单位—节数,以固定长度的每节描述;坐标–整型;颜色–整型; 位置–X,Y坐标。

增加的描述:蛇运动的方向,蛇的生命。

对应数据与数据类型:这些描述是为了与程序的按键的输入部分与判断游戏结束部分相联系而设的。方向只有四个方向:上下左右。可以设置与之对应的四个整型数:3、4、2、1。生命就只有两种情况:死或生,对应0或1。

食物:

基本描述:颜色,位置。

对应数据与数据类型:由于颜色设成固定的,所以不再讨论。位置—X、Y坐标。

增加的描述:食物的存在。

对应数据与数据类型:这是为了避免重复出现食物而设置的,与绘制食物的函数有联系。只有两个值:0或1(没有食物或有食物)

其他的元素:墙,由于它在显示上是作为背景而存在的,所以并没有什么说明实际的墙壁就是四条直线组成的边框,由坐标描述。

还需要的变量:键盘键入的键值(作为全局变量,整型);经常要使用的循环变量;自定义的填充图案;说明文字的字符数组;游戏的记分;游戏的速度(蛇的速度)。

图2.2蛇的不停运动的关键算法的流程图

2.2.4各模块的功能及程序说明

主要模块的实现思路和算法的流程图说明:

关键所在——蛇不停移动的Snakemove():

蛇的不停移动,就是蛇的下一节取代前一节的位置,在计算机中就是蛇下一节的位置坐标变成前一节的位置坐标。在上文中,已定义蛇的位置坐标为数组类型,一组坐标对应一节的位置,假设有i+1节,由0到i节,第i节的坐标取第i-1节的坐标,第i-1节的坐标取第i-2节的坐标……直到第1节取第0节的坐标。而第0节的坐标,即蛇头的坐标要往某个方向变化,变化量为蛇每节的长度。蛇的这种坐标轮换需要循环语句使其继续下去。

2.2.5程序结果

运行程序得到如下初始界面图:

图2.3程序结果图

用一个小矩形表示蛇的一节身体,身体每长一节,增加一个矩形块,蛇头用两节表示:

图2.4程序结果图

蛇没有碰到自己或墙壁,蛇继续前进:

图2.5程序结果图

游戏结束时,显示“GAME OVER”

图2.6程序结果图

2.3程序源代码及注释

#define N 200

#include graphics.h

#include stdlib.h

#include dos.h

#define LEFT 0x4b00

#define RIGHT 0x4d00

#define DOWN 0x5000

#define UP 0x4800

#define ESC 0x011b

int i,key;

int score=0;/*得分*/

int gamespeed=50000;/*游戏速度自己调整*/

struct Food{

int x;/*食物的横坐标*/

int y;/*食物的纵坐标*/

int yes;/*判断是否要出现食物的变量*/

}food;/*食物的结构体*/

struct Snake{

int x[N];

int y[N];

int node;/*蛇的节数*/

int direction;/*蛇移动方向*/

int life;/* 蛇的生命,0活着,1死亡*/

}snake;

void Init(void);/*图形驱动*/

void Close(void);/*图形结束*/

void DrawK(void);/*开始画面*/

void GameOver(void);/*结束游戏*/

void GamePlay(void);/*玩游戏具体过程*/

void PrScore(void);/*输出成绩*/

/*主函数*/

void main(void){

Init();/*图形驱动*/

DrawK();/*开始画面*/

GamePlay();/*玩游戏具体过程*/

Close();/*图形结束*/}

/*图形驱动*/

void Init(void){

int gd=DETECT,gm;

registerbgidriver(EGAVGA_driver);

initgraph(gd,gm,”c:\\program files\\winyes\\tc20h\\bgi”);

cleardevice();}

/*开始画面,左上角坐标为(50,40),右下角坐标为(610,460)的围墙*/

void DrawK(void){

/*setbkcolor(LIGHTGREEN);*/

setcolor(11);

setlinestyle(SOLID_LINE,0,THICK_WIDTH);/*设置线型*/

for(i=50;i=600;i+=10)/*画围墙*/   {

rectangle(i,40,i+10,49); /*上边*/

rectangle(i,451,i+10,460);/*下边*/   }

for(i=40;i=450;i+=10)  {

rectangle(50,i,59,i+10); /*左边*/

rectangle(601,i,610,i+10);/*右边*/ }}

/*玩游戏具体过程*/

void GamePlay(void){

randomize();/*随机数发生器*/

food.yes=1;/*1表示需要出现新食物,0表示已经存在食物*/

snake.life=0;/*活着*/

snake.direction=1;/*方向往右*/

snake.x[0]=100;snake.y[0]=100;/*蛇头*/

snake.x[1]=110;snake.y[1]=100;

snake.node=2;/*节数*/

PrScore();/*输出得分*/

while(1)/*可以重复玩游戏,压ESC键结束*/   {

while(!kbhit())/*在没有按键的情况下,蛇自己移动身体*/      {

if(food.yes==1)/*需要出现新食物*/     {

food.x=rand()%400+60;

food.y=rand()%350+60;

while(food.x%10!=0)/*食物随机出现后必须让食物能够在整格内,这样才可以让蛇吃到*/

food.x++;

while(food.y%10!=0)

food.y++;

food.yes=0;/*画面上有食物了*/     }

if(food.yes==0)/*画面上有食物了就要显示*/     {

setcolor(GREEN);

rectangle(food.x,food.y,food.x+10,food.y-10);     }

for(i=snake.node-1;i0;i–)/*蛇的每个环节往前移动,也就是贪吃蛇的关键算法*/         {

snake.x[i]=snake.x[i-1];

snake.y[i]=snake.y[i-1];     }

/*1,2,3,4表示右,左,上,下四个方向,通过这个判断来移动蛇头*/

switch(snake.direction)     {

case 1:snake.x[0]+=10;break;

case 2: snake.x[0]-=10;break;

case 3: snake.y[0]-=10;break;

case 4: snake.y[0]+=10;break;     }

for(i=3;isnake.node;i++)/*从蛇的第四节开始判断是否撞到自己了,因为蛇头为两节,第三节不可能拐过来*/     {

if(snake.x[i]==snake.x[0]snake.y[i]==snake.y[0])        {

GameOver();/*显示失败*/

snake.life=1;

break;        }        }

if(snake.x[0]55||snake.x[0]595||snake.y[0]55||

snake.y[0]455)/*蛇是否撞到墙壁*/    {

GameOver();/*本次游戏结束*/

snake.life=1; /*蛇死*/    }

if(snake.life==1)/*以上两种判断以后,如果蛇死就跳出内循环,重新开始*/

break;

if(snake.x[0]==food.xsnake.y[0]==food.y)/*吃到食物以后*/    {

setcolor(0);/*把画面上的食物东西去掉*/

rectangle(food.x,food.y,food.x+10,food.y-10);

snake.x[snake.node]=-20;snake.y[snake.node]=-20;

/*新的一节先放在看不见的位置,下次循环就取前一节的位置*/

snake.node++;/*蛇的身体长一节*/

food.yes=1;/*画面上需要出现新的食物*/

score+=10;

PrScore();/*输出新得分*/    }

setcolor(4);/*画出蛇*/

for(i=0;isnake.node;i++)

rectangle(snake.x[i],snake.y[i],snake.x[i]+10,

snake.y[i]-10);

delay(gamespeed);

setcolor(0);/*用黑色去除蛇的的最后一节*/

rectangle(snake.x[snake.node-1],snake.y[snake.node-1],

snake.x[snake.node-1]+10,snake.y[snake.node-1]-10);     }  /*endwhile(!kbhit)*/

if(snake.life==1)/*如果蛇死就跳出循环*/

break;

key=bioskey(0);/*接收按键*/

if(key==ESC)/*按ESC键退出*/

break;

else

if(key==UPsnake.direction!=4)

/*判断是否往相反的方向移动*/

snake.direction=3;

else

if(key==RIGHTsnake.direction!=2)

snake.direction=1;

else

if(key==LEFTsnake.direction!=1)

snake.direction=2;

else

if(key==DOWNsnake.direction!=3)

snake.direction=4;

}/*endwhile(1)*/}

/*游戏结束*/

void GameOver(void){

cleardevice();

PrScore();

setcolor(RED);

settextstyle(0,0,4);

outtextxy(200,200,”GAME OVER”);

getch();}

/*输出成绩*/

void PrScore(void){

char str[10];

setfillstyle(SOLID_FILL,YELLOW);

bar(50,15,220,35);

setcolor(6);

settextstyle(0,0,2);

sprintf(str,”score:%d”,score);

outtextxy(55,20,str);}

/*图形结束*/

void Close(void){

getch();

closegraph();

}

简单c语言课程设计

C语言课程设计

/*计算上个月每个人每种产品的销售额。

1)按销售额对销售员进行排序,输出排序结果(销售员代号)

2)统计每种产品的总销售额,对这些产品按从高到底的顺序,输出排序结果(需输出产品的代号和销售额)

3)输出统计报表如下:*/

#include stdio.h

#include string.h

#include conio.h

#include stdlib.h

#define Z 5

#define R 4 /*定义宏常量便于程序的一般化*/ /*R表示销售员个数*/

typedef struct /*缩短结构体变量名*/

{

int shangpin[Z]; /*定义结构体便于信息的存储和读写,辨别*/ /*R是表示商品的种类,最后一个为该销售员商品总和*/

}data;

void menu()

{ printf(” *******************************************************\n”);

printf(” 0.结束操作\n”);

printf(” 1.计算上个月每个人每种产品的销售额\n”);

printf(” 2.按销售额对销售员进行排序,输出排序结果\n”);

printf(” 3.统计每种产品的总销售额,输出排序结果\n”);

printf(” 4.输出统计报表\n”);

printf(” ******************************************************\n”);

}

void data_read(data *x) /*读入函数使程序简洁*/

{

FILE *fp;

char fname[10];

int i;

printf(“您想查询哪个月?\n”);

printf(“请输入月份:”); /*输入文件名,这样可以进行各个月份信息读入*/

scanf(“%s”,fname);

strcat(fname,”.txt”);/*连接文件属性*/

if((fp=fopen(fname,”rb”))==NULL) /*打开文件*/

{

printf(“can not open the file\n”);

exit(0);

}

for(i=0;iR;i++) /*读出信息*/

if(fread(x+i,sizeof(data),1,fp)!=1)

printf(“读入信息出错!\n”);

}

void data_count(data *x) /*计算上个月每个人每种产品的销售额*/

{

FILE *fp;

char fname[10];

int j,t; /*用于控制循环*/

int i,k,s; /*用于定义职工序号,产品序号,产品数量*/

system(“cls”);

printf(“您想计算哪个月?\n”);

printf(“请输入月份:”); /*输入文件名,这样可以进行各个月份信息写入*/

scanf(“%s”,fname);

strcat(fname,”.txt”);

if((fp=fopen(fname,”wb”))==NULL) /*打开文件*/

{

printf(“can not open the file\n”);

exit(0);

}

for(j=0;jR;j++) /*对商品数量清零*/

for(t=0;tZ;t++)

(x+j)-shangpin[t]=0;

printf(“please put the information about the 职工编号,产品编号,销售数量\n”); /*写入信息*/

for(j=0;;j++)

{

scanf(“%d%d%d”,i,k,s);

if(i==0) /*输入职工为0时结束信息输入*/

break;

if(iR||i0||kZ||k0)

{

printf(“the information error!\n”); /*避免输入信息出错*/

continue;

}

else

(x+i-1)-shangpin[k-1]=(x+i-1)-shangpin[k-1]+s;/*统计各个人的各种产品的数量,-1为了和数组中的序号相匹配*/

}

for(j=0;jR;j++)

if(fwrite((x+j),sizeof(data),1,fp)!=1) /*把信息写入文件中便有以后调用*/

printf(“write error!\n”);

fclose(fp); /*关闭文件避免信息遗漏*/

}

void range_sxy(data *x) /*按销售额对销售员进行排序,输出排序结果*/

{

FILE *fp;

char fname[10];

int i,k,j,t,bianhao[R]={0},z;

system(“cls”);

printf(“你要哪个月的?\n”);

printf(“请输入月份:”); /*输入文件名,这样可以进行各个月份信息读入*/

scanf(“%s”,fname);

strcat(fname,”.txt”);

if((fp=fopen(fname,”rb”))==NULL) /*打开文件*/

{

printf(“can not open the file\n”);

exit(0);

}

for(i=0;iR;i++) /*读出信息*/

if(fread(x+i,sizeof(data),1,fp)!=1)

printf(“读入信息出错!”); /*读入信息提示*/

for(i=0;iR;) /*用于存储职工编号*/

bianhao[i]=i++;

printf(“请输入按何种产品排序\n”);

scanf(“%d”,k);

k=k-1; /*便于与结构体中的数组值对应*/

for(i=0;iR;i++) /*按K种产品对销售员排序,选择法排序*/

{

t=i;

for(j=i+1;jR;j++)

if((x+bianhao[t])-shangpin[k](x+bianhao[j])-shangpin[k])/*调用职工各自对应的结构体内的产品数量*/

t=j;

if(t!=i)

{

z=bianhao[i];

bianhao[i]=bianhao[t];

bianhao[t]=z;

}

}

printf(“按%d产品对销售员排序为:\n”,k+1);

for(i=0;iR;i++)

printf(“%5d”,bianhao[i]+1);

getch();

fclose(fp);

}

void range_shangpin(data *x) /*统计每种产品的总销售额,输出排序结果*/

{

FILE *fp;

char fname[10];

int i,j,sum[Z]={0},bianhao[Z]={0},z,t,k;

system(“cls”);

printf(“您想计算哪个月的?\n”);

printf(“请输入月份:”); /*输入文件名,这样可以进行各个月份信息读入*/

scanf(“%s”,fname);

strcat(fname,”.txt”);

if((fp=fopen(fname,”rb”))==NULL) /*打开文件*/

{

printf(“can not open the file\n”);

exit(0);

}

for(i=0;iR;i++) /*读出信息*/

if(fread(x+i,sizeof(data),1,fp)!=1)

printf(“读入信息出错!”);

for(i=0;iZ;i++) /*对各种商品求和*/

for(j=0;jR;j++)

sum[i]=sum[i]+(x+j)-shangpin[i];

for(i=0;iZ;) /*用于存储商品编号*/

bianhao[i]=i++;

for(i=0;iZ;i++)

printf(“%3d”,bianhao[i]);

for(i=0;iZ;i++) /*对产品从高到低排序,选择法排序*/

{

t=i;

for(j=i+1;jZ;j++) /*产品变化时,产品编号也随之变化,便于输出*/

if(sum[t]sum[j])

t=j;

if(t!=i)

{

k=sum[i];

sum[i]=sum[t];

sum[t]=k;

z=bianhao[i];

bianhao[i]=bianhao[t];

bianhao[t]=z;

}

}

printf(“输出产品排序\n”);

printf(“产品编号 数量\n”);

for(i=0;iZ;i++)

printf(“%-10d%-10d\n”,bianhao[i]+1,sum[i]);

getch();

fclose(fp);

}

void data_out(data *x) /*输出统计报表*/

{

FILE *fp;

char fname[10];

int i,j,sum[Z+1]={0};

system(“cls”);

printf(“您想计算哪个月?\n”);

printf(“请输入月份:”); /*输入文件名,这样可以进行各个月份信息读入*/

scanf(“%s”,fname);

strcat(fname,”.txt”);

if((fp=fopen(fname,”rb”))==NULL) /*打开文件*/

{

printf(“can not open the file\n”);

exit(0);

}

for(i=0;iR;i++) /*读出信息*/

if(fread(x+i,sizeof(data),1,fp)!=1)

printf(“读入信息出错!”);

for(i=0;iZ;i++) /*对各种商品求和*/

for(j=0;jR;j++)

sum[i]=sum[i]+(x+j)-shangpin[i];

for(i=0;iZ;i++) /*求商品总和*/

sum[Z]=sum[Z]+sum[i];

printf(“输出统计报表如下:\n”); /*按要求输出统计表*/

printf(“产品代号 销售之和 销售员代号\n”);

for(i=0;iR;i++)

for(j=0;jZ;j++)

printf(“%-10d%-10d%-10d\n”,j+1,(x+i)-shangpin[j],i+1);

printf(“***********************************\n”);

for(i=0;iZ;i++)

{

if(i==0)

printf(“%d产品之和 %-10d 总和 %-10d\n”,i+1,sum[i],sum[Z]);

else

printf(“%d产品之和 %-10d\n”,i+1,sum[i]);

}

getch();

}

void main()

{

int i,choice;

data sxy[R]; /*R表示职工的个数,前面的宏常量*/

for(i=0;;i++)

{

system(“cls”); /*清频命令*/

menu(); /*菜单函数提示用户怎样选择*/

printf(“你想做什么?\n”);

printf(“请选择:”); /*输入要进行的操作*/

scanf(“%d”,choice);

if(choice==0) /*退出程序*/

break;

else

switch(choice)

{

case 1 : data_count(sxy);break; /*计算上个月每个人每种产品的销售额*/

case 2 : range_sxy(sxy);break; /*按销售额对销售员进行排序,输出排序结果*/

case 3 : range_shangpin(sxy);break; /*统计每种产品的总销售额,输出排序结果*/

case 4 : data_out(sxy);break; /*输出统计报表*/

}

}

}

用C语言设计一个简单计算器的课程设计(希望能尽可能的详细,多一些)

//名字记不太清了,这个叫递归下降算法,但这个算法肯定是首先在编译原理中的,主要用在

//各种编译器中。就是现扫描整个表达式字符串,把其中的运算符找出来,判断它们的优先级

//然后按从左到右的顺序先计算把优先级低的运算符和它两边的数据压入,这样循环做过以后

//再从头取出一个一个计算,表达式的结构类似与二叉树,遍历二叉树后把结果存在连表中供

//计算。你这个程序问题好像比较多啊。用的数据结构类型和函数名根本就不配套

#include stdio.h

struct s_node //节点结构体

{

int data;

struct s_node *next;

};

typedef struct s_node s_list;

typedef s_list *link;

link operator=NULL;

link operand=NULL;

link push(link stack,int value) //向链表添加数据

{

link newnode;

newnode=(link) malloc(sizeof(s_list));

if(!newnode)

{

printf(“\nMemory allocation failure!!!”);

return NULL;

}

newnode-data=value;

newnode-next=stack;

stack=newnode;

return stack;

}

link pop(link stack,int *value) //从链表取出数据

{

link top;

if(stack !=NULL)

{

top=stack;

stack=stack-next;

*value=top-data;

free(top);

return stack;

}

else

*value=-1;

}

int empty(link stack) //判断链表是否为空

{

if(stack==NULL)

return 1;

else

return 0;

}

int is_operator(char operator) //判断是否是运算符号

{

switch (operator)

{

case ‘+’: case ‘-‘: case ‘*’: case ‘/’: return 1;

default:return 0;

}

}

int priority(char operator) //判断运算符优先级

{

switch(operator)

{

case ‘+’: case ‘-‘ : return 1;

case ‘*’: case ‘/’ : return 2;

default: return 0;

}

}

int two_result(int operator,int operand1,int operand2) //计算数值,计算器的核心

{

switch(operator)

{

case ‘+’:return(operand2+operand1);

case ‘-‘:return(operand2-operand1);

case ‘*’:return(operand2*operand1);

case ‘/’:return(operand2/operand1);

}

}

void main()

{

char expression[50];

int position=0;

int op=0;

int operand1=0;

int operand2=0;

int evaluate=0;

printf(“\nPlease input the inorder expression:”);

gets(expression);

while(expression[position]!=’\0’expression[position]!=’\n’)

{

if(is_operator(expression[position]))

{

if(!empty(operator))

while(priority(expression[position])= priority(operator-data)

!empty(operator))

{

operand=pop(operand,operand1);

operand=pop(operand,operand2);

operator=pop(operator,op);

operand=push(operand,two_result(op,operand1,operand2));

}

operator=push(operator,expression[position]);

}

else

operand=push(operand,expression[position]-48);

position++;

}

while(!empty(operator))

{

operator=pop(operator,op);

operand=pop(operand,operand1);

operand=pop(operand,operand2);

operand=push(operand,two_result(op,operand1,operand2));

}

operand=pop(operand,evaluate);

printf(“The expression [%s] result is ‘%d’ “,expression,evaluate);

getch();

}

C语言课程设计“““`简单的

for(i=0;i10;i++)

{

if(a[i]%12==0)

b[i]=T;

else

b[i]=F;

printf();

}

本文来自投稿,不代表【】观点,发布者:【

本文地址: ,如若转载,请注明出处!

举报投诉邮箱:253000106@qq.com

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2024年3月27日 15:43:23
下一篇 2024年3月27日 15:53:46

相关推荐

  • c语言改写模式,c语言实现修改功能

    c语言程序修改? 1、这个程序有4个错误,我都加粗了,第一个是m没有赋初值,第二个是while表达式中的ch=getchar()需要括号括起来,第三个是m=m*10+ch-0中的0也需要用单引号括起来,第四个是第2个while中为m!=0。 2、define容易造成误会,因为不符合一般的编程习惯,false 0, true 1;scanf放在你的那个地方是达…

    2024年5月23日
    3900
  • c语言控制代码的换码序列,c语言交换代码

    求C语言编程大神解答一下下面这个编程代码? k==5,用5去除125余0,所以r=125%5中r为0。由于!0为1,所以执行while循环体:先打印出5(k的值),再n=n/k==125/5=25;由于251则再打印出*号。这一循环结果输出是5*。 下面是我的代码,三个函数分别对应三个问题。 在实现基本要求的前提下,拓展了可以从键盘输入的功能,以下为各题代码…

    2024年5月23日
    5600
  • c语言扫描io脚状态,c语言端口扫描

    求51单片机的上升沿和下降沿C语言检测程序列子,端口就是普通IO口。 上升沿触发是当信号有上升沿时的开关动作,当电位由低变高而触发输出变化的就叫上升沿触发。也就是当测到的信号电位是从低到高也就是上升时就触发,叫做上升沿触发。 单片机怎么计算1s内下降沿的个数的C语言程序或者计算两个下降沿的时间(检测脉冲频率)计算1s内下降沿的个数方法是,一个定时器设置定时1…

    2024年5月23日
    4400
  • c语言mallloc使用的简单介绍

    C语言中使用malloc必须加#includemallo.h? 1、在C语言中使用malloc函数进行动态内存分配。malloc的全称是memory allocation,中文叫动态内存分配。原型:extern void malloc(unsigned int num_bytes);功能:分配长度为num_bytes字节的内存块。 2、你可以看一下C语言那本…

    2024年5月23日
    4400
  • c语言三位小数,C语言三位小数

    怎样用C++语言输出精确到小数点后三位的数? 1、用C++语言输出精确到小数点后三位的数,可以参考下面给出的代码:coutsetiosflags(ios:fixed)setprecision(3)。其中 setiosflags中set是设置的意思。ios是iostream的缩写,即输入输出流。flags是标志的意思。 2、要精确到小数点后若干位,则数据类型为…

    2024年5月23日
    7300
  • c语言21点游戏,二十一点游戏代码c语言

    如何使用C语言编写简单小游戏? 1、数学知识:长方形的面积S=a*b 长方形周长L=2*(a+b)其中a b分别为长方形的宽和高。算法分析:长方形面积及周长均依赖于宽和高,所以先要输入宽高值,然后根据公式计算,输出结果即可。 2、/*也不知道你是什么级别的,我是一个新手,刚接触编程语言,以下是我自己变得一个小程序,在所有c语言的编译器(vc++0、turbo…

    2024年5月23日
    6400
  • javascriptcanvas的简单介绍

    如何使用js在画布上绘制图形 1、可以使用 drawImage()方法把一幅图像绘制到画布上。 以使用三种不同的参数组合。最简单的调用方式是传入一个 HTML 元素,以及绘制该图像的起点的 x 和 y 坐标。 2、效果图:使用JavaScript在画布中绘制文本图形首先我们来看看要在画布上绘制文本图形,需要用到的最重要的属性和方法:font属性:定义文本的字…

    2024年5月23日
    4200
  • cortexm4linux的简单介绍

    Cortex-M4的主要功能 Cortex-M4提供了无可比拟的功能,以将[1] 32位控制与领先的数字信号处理技术集成来满足需要很高能效级别的市场。 Cortex-M4核心具有浮点单元(FPU)单精度,支持所有Arm单精度数据处理指令和数据类型。它还实现了一套完整的DSP指令和一个提高应用程序安全性的内存保护单元(MPU)。 主要是m4比m3多了dsp的支…

    2024年5月23日
    4300
  • c语言当中的null,C语言当中的符号

    C/C++中,NULL和null的区别是什么? nul 和 null要看编译器,不同的编译器有所区别。 所以C或者C++中都使用一个特殊定义NULL表示无效值,其本质就是未定义具体数据类型的0值。 null是是什么都没有的意思。在java中表示空对象。 本意是“空的;元素只有零的”意思。计算机中通常表示空值,无结果,或是空集合。\x0d\x0a在ASCII码…

    2024年5月23日
    4500
  • 3desjavaphp的简单介绍

    php的3des加密结果与java不一致 他们的加密算法都是通用的,是可以解开的,只要你des的模式,加密长度,初始向量什么的都一样就可以。 JAVA写RSA加密,私钥都是一样的,公钥每次加密的结果不一样跟对数据的padding(填充)有关。Padding(填充)属性定义元素边框与元素内容之间的空间。padding简写属性在一个声明中设置所有内边距属性。 要…

    2024年5月23日
    4700

发表回复

登录后才能评论



关注微信