本站提供最佳php源码个人模板服务,欢迎转载和分享。

【微信家政源码】【武汉网游源码开发】【网站防盗源码在哪里】c 实例 源码_c源代码例子

2024-11-30 01:28:14 来源:传2源码 分类:娱乐

1.用C语言写的例源计算器源代码
2.C语言10个经典开源项目
3.C语言爱心代码,C语言爱心代码大全
4.c语言游戏代码大全(收录100多款经典游戏源码)
5.C语言的经典编程例子

c   实例 源码_c源代码例子

用C语言写的码c码例计算器源代码

       #include<stdio.h>

       #include<iostream.h>

       #include<stdlib.h>

       #include<string.h>

       #include<ctype.h>

       typedef float DataType;

       typedef struct

       {

        DataType *data;

        int max;

        int top;

       }Stack;

       void SetStack(Stack *S,int n)

       {

        S->data=(DataType*)malloc(n*sizeof(DataType));

        if(S->data==NULL)

        {

        printf("overflow");

        exit(1);

        }

        S->max=n;

        S->top=-1;

       }

       void FreeStack(Stack *S)

       {

        free(S->data);

       }

       int StackEmpty(Stack *S)

       {

        if(S->top==-1)

        return(1);

        return(0);

       }

       DataType Peek(Stack *S)

       {

        if(S->top==S->max-1)

        {

        printf("Stack is empty!\n");

        exit(1);

        }

        return(S->data[S->top]);

       }

       void Push(Stack *S,DataType item)

       {

        if(S->top==S->max-1)

        {

        printf("Stack is full!\n");

        exit(1);

        }

        S->top++;

        S->data[S->top]=item;

       }

       DataType Pop(Stack *S)

       {

        if(S->top==-1)

        {

        printf("Pop an empty stack!\n");

        exit(1);

        }

        S->top--;

        return(S->data[S->top+1]);

       }

       typedef struct

       {

        char op;

        int inputprecedence;

        int stackprecedence;

       }DataType1;

       typedef struct

       {

        DataType1 *data;

        int max;

        int top;

       }Stack1;

       void SetStack1(Stack1 *S,int n)

       {

        S->data=(DataType1*)malloc(n*sizeof(DataType1));

        if(S->data==NULL)

        {

        printf("overflow");

        exit(1);

        }

        S->max=n;

        S->top=-1;

       }

       void FreeStack1(Stack1 *S)

       {

        free(S->data);

       }

       int StackEmpty1(Stack1 *S)

       {

        if(S->top==-1)

        return(1);

        return(0);

       }

       DataType1 Peek1(Stack1 *S)

       {

        if(S->top==S->max-1)

        {

        printf("Stack1 is empty!\n");

        exit(1);

        }

        return(S->data[S->top]);

       }

       void Push1(Stack1 *S,DataType1 item)

       {

        if(S->top==S->max-1)

        {

        printf("Stack is full!\n");

        exit(1);

        }

        S->top++;

        S->data[S->top]=item;

       }

       DataType1 Pop1(Stack1 *S)

       {

        if(S->top==-1)

        {

        printf("Pop an empty stack!\n");

        exit(1);

        }

        S->top--;

        return(S->data[S->top+1]);

       }

       DataType1 MathOptr(char ch)

       {

        DataType1 optr;

        optr.op=ch;

        switch(optr.op)

        {

        case'+':

        case'-':

        optr.inputprecedence=1;

        optr.stackprecedence=1;

        break;

        case'*':

        case'/':

        optr.inputprecedence=2;

        optr.stackprecedence=2;

        break;

        case'(':

        optr.inputprecedence=3;

        optr.stackprecedence=-1;

        break;

        case')':

        optr.inputprecedence=0;

        optr.stackprecedence=0;

        break;

        }

        return(optr);

       }

       void Evaluate(Stack *OpndStack,DataType1 optr)

       {

        DataType opnd1,opnd2;

        opnd1=Pop(OpndStack);

        opnd2=Pop(OpndStack);

        switch(optr.op)

        {

        case'+':

        Push(OpndStack,opnd2+opnd1);

        break;

        case'-':

        Push(OpndStack,opnd2-opnd1);

        break;

        case'*':

        Push(OpndStack,opnd2*opnd1);

        break;

        case'/':

        Push(OpndStack,opnd2/opnd1);

        break;

        }

       }

       int isoptr(char ch)

       {

        if(ch=='+'||ch=='-'||ch=='*'||ch=='/'||ch=='(')

        return(1);

        return(0);

       }

       void Infix(char *str)

       {

        int i,k,n=strlen(str);

        char ch,numstr[];

        DataType opnd;

        DataType1 optr;

        Stack OpndStack;

        Stack1 OptrStack;

        SetStack(&OpndStack,n);

        SetStack1(&OptrStack,n);

        k=0;

        ch=str[k];

        while(ch!='=')

        if(isdigit(ch)||ch=='.')

        {

        for(i=0;isdigit(ch)||ch=='.';i++)

        {

        numstr[i]=ch;

        k++;

        ch=str[k];

        }

        numstr[i]='\0';

        opnd= atof(numstr);

        Push(&OpndStack,opnd);

        }

        else

        if(isoptr(ch))

        {

        optr=MathOptr(ch);

        while(Peek1(&OptrStack).stackprecedence>=optr.inputprecedence)

        Evaluate(&OpndStack,Pop1(&OptrStack));

        Push1(&OptrStack,optr);

        k++;

        ch=str[k];

        }

        else if(ch==')')

        {

        optr=MathOptr(ch);

        while(Peek1(&OptrStack).stackprecedence>=optr.inputprecedence)

        Evaluate(&OpndStack,Pop1(&OptrStack));

        Pop1(&OptrStack);

        k++;

        ch=str[k];

        }

        while(!StackEmpty1(&OptrStack))

        Evaluate(&OpndStack,Pop1(&OptrStack));

        opnd=Pop(&OpndStack);

        cout<<"你输入表达式的计算结果为"<<endl;

        printf("%-6.2f\n",opnd);

        FreeStack(&OpndStack);

        FreeStack1(&OptrStack);

       }

       void main()

       {

        cout<<"请输入你要计算的表达式,并以“=”号结束。"<<endl;

        char str[];

        gets(str);

        Infix(str);

       =================================================================

       哈哈!源代给分吧!例源

C语言个经典开源项目

       C语言个经典开源项目

       一、码c码例Webbench

       Webbench是源代微信家政源码一款用于linux下的网站压测工具,通过模拟多个客户端并发访问指定URL,例源测试网站在高负载下的码c码例性能。最多支持3万并发连接,源代代码简洁,例源总共不到行。码c码例

       下载链接: home.tiscali.cz/~cz...

       二、源代CMockery

       CMockery是例源Google提供的一款轻量级的C语言单元测试框架,简洁且无需依赖其他开源包,码c码例对被测试代码的源代侵入性低。源代码不到3K行。

       主要特点:免费开源、兼容旧版本编译器、无需C标准依赖。

       下载链接: code.google.com/p/cmock...

       三、Libev

       Libev是武汉网游源码开发一个基于epoll、kqueue等OS基础设施的高效事件驱动库,使用Reactor模式处理IO事件、定时器和信号,代码量少至4.版本的多行。

       下载链接: software.schmorp.de/pkg...

       四、Memcached

       Memcached是一个用于动态Web应用的高性能分布式内存对象缓存系统,通过缓存数据和对象减少数据库读取次数,加速动态数据库驱动网站的速度。Memcached-1.4.7版本代码量在K行左右。

       下载地址: a distributed memory object caching system

       五、网站防盗源码在哪里SQLite

       SQLite是一个开源的嵌入式关系数据库引擎,实现自包容、零配置,支持事务的SQL数据库,代码量约3万行,大小K。

       下载地址: SQLite Home Page

       六、Redis

       Redis是一个使用ANSI C编写的开源数据结构服务器,代码量相对较小(4.5w行),几乎不依赖其他库,直播空降源码下载软件大部分为单线程。

       下载地址: Redis

       七、Nginx

       Nginx是一款高性能的HTTP和反向代理服务器,设计简洁、功能丰富,具有低系统资源消耗的特性。已发布多年,获得广泛好评。

       下载地址: /doc/DV0hOY3...

c语言游戏代码大全(收录多款经典游戏源码)

       C语言是一种广泛使用的编程语言,其强大的海外仓库管理系统源码功能和高效的性能使其成为游戏开发的首选语言。本文将介绍多款经典游戏的C语言源码,供游戏开发者学习和参考。

       操作步骤

       Step1:下载源码

       访问Github上的C语言游戏代码大全仓库,找到需要的游戏源码,点击“Download”按钮下载源码压缩包。

       Step2:解压源码

       使用解压软件将下载的源码压缩包解压到本地硬盘上。

       Step3:编译源码

       使用C语言编译器(如GCC)编译源码,生成可执行文件。

       Step4:运行游戏

       运行生成的可执行文件,开始游戏。

       经典游戏源码

       1.俄罗斯方块

       俄罗斯方块是一款经典的益智游戏,玩家需要通过旋转和移动方块,使其在下落过程中排列成完整的一行或多行,从而消除方块并得分。

       操作步骤

       使用方向键控制方块移动和旋转,按空格键加速方块下落。

       2.扫雷

       扫雷是一款经典的单人益智游戏,玩家需要根据周围的数字推断出隐藏在方格中的地雷位置,最终揭开所有非地雷方格并得分。

       操作步骤

       使用鼠标左键点击方格揭开,使用鼠标右键标记可能的地雷位置。

       3.贪吃蛇

       贪吃蛇是一款经典的单人游戏,玩家需要通过控制一条蛇在屏幕上移动,吃掉食物并不断成长,直到撞到墙壁或自己的身体为止。

       操作步骤

       使用方向键控制蛇的移动方向,吃到食物后蛇的长度加1。

       4.五子棋

       五子棋是一款经典的两人对弈游戏,玩家需要通过在棋盘上下棋,先在横、竖、斜方向上连成五子的一方获胜。

       操作步骤

       使用鼠标点击棋盘上的空格下棋,先连成五子的一方获胜。

       5.推箱子

       推箱子是一款经典的益智游戏,玩家需要通过推动箱子使其到达指定位置,最终完成所有关卡。

       操作步骤

       使用方向键控制人物移动和推动箱子,将箱子推到指定位置即可过关。

C语言的经典编程例子

       //最经典的当然是HelloWorld了。 

       #include "stdio.h"

       int main(void)

       {

          printf("HelloWorld!\r\n");

       }

【本文网址:http://0553.net.cn/news/21b637093608.html 欢迎转载】

copyright © 2016 powered by 皮皮网   sitemap