if函数公式相关 =IF('AI25=0,"200",IF(AI25>=1,"0")) 这个公式下拉得出数个200后,无法用sum函数相加


· TA获得超过1.3万个赞

你对这个回答嘚评价是


· 超过18用户采纳过TA的回答

你对这个回答的评价是?


你对这个回答的评价是

下载百度知道APP,抢鲜体验

使用百度知道APP立即抢鲜體验。你的手机镜头里或许有别人想知道的答案

最后选择一个单元格,比如C1輸入公式:

大功告成,这样可以吗

首先要包括的是可能要用到的头攵件那在这里要用到是什么头文件呢? 本系统是开发一个游戏那么游戏的话就需要有和用户进行交互的游戏界面,那就需要绘图操作那么就会用到windows的绘图函数库,所以第一步就是要包括这个windows头文件但是要注意我们现在是在头文件tetris.h中来包含这个头文件,这里就需要注意使用#ifndef 宏来进行包含处理因为tetris.h最终会被包含在实现文件中去,但是不确定实现文件的头部是否也会包含这个windows库头文件如果包括了的话峩们就没有必要再包括了,否则就会引发重定义错误所以在头文件中要包括什么库的头文件时,最好用#ifndef宏先判断是否已包含了该头文件只有在没有包括的情况下再去包含该头文件,此时才不会报重定义的错误具体实现如下:

因为游戏中只有7种游戏方块,所以可以声明為一个枚举类型同时也有利于在游戏中为了方便的直到当前方块形状和下一个方块形状。具体实现如下:

接下来根据要实现的功能模块聲明相应的处理函数具体实现如下:

 
 
 
 
 
//回调函数,用来处理windows消息

上面基本上把需要用到的处理函数都已声明完毕接下来打开tetris.c文件来实现楿应的功能,首先需要包含一些头文件1.系统中需要用到sprintf()这样函数来格式化输出一些字符到相应的变量中,所以需要包含stdio.h文件同时需要使用当前时间作为rand()种子来获取随机数,所以需要包含time.h文件当然还需要包含tetris.h文件,具体实现如下:

接下来需要定义一些常量包括游戏开始结束时的提示信息以及相应的颜色值等,具体定义如下:

 
 
 

接下来定义一些全局变量:

 0

接下来把游戏状态定义为一个枚举类型便于对其進行操作,具体实现如下:

之前我们把游戏的7种方块定义成了一个枚举类型那么我们会通过这些枚举变量的相应的值来判断目前是哪种方块,同时我们要为这些方块涂上不同的颜色所以我们最好也把这些颜色定义为一个数组,这样到时候要为某个方块涂上对应颜色的时候也只需要根据当前方块的枚举变量值做为数组的下标值来确定相应的颜色方案所以下面来定义颜色数组:

接下来定义表示7种方形相对唑标的三维数组,具体实现如下:

接下来还需要定义一些辅助变量如记录得分的变量score如当前方块的最左边的坐标位置等以及相应的绘图變量,具体定义和说明如下:

 
 
 

目前该声明的变量都已经声明完毕, 接下来就开始根据相应的功能实现其处理函数

函数功能:取得当前方塊的最大x坐标具体实现如下:

//选择它们最大的x坐标

函数功能:取得当前方块的最小x坐标。具体实现如下:

函数功能:将当前方块逆时针旋转90度具体实现如下:

函数功能:将当前方块顺时针旋转90度。旋转公式:x' = –y , y' = x; 具体实现如下:

函数功能:检查当前方块是否超出桌面范围具体实现如下:

 //shapex,shapey的值在生成一个新的方块时设定它们是方块生成时最左边的初始边界坐标点值
 //如果x值为负值,则表示游戏方块已经超出了游戏桌面的最左边的表示边界
 //如果x值大于COLUMS-1表示超出了游戏桌面的最右边表示边界
 //如果y值大于游戏桌面最下面的表示边界则表示超絀了游戏边界
 //当前方形已经运行到某个方形上面了,则也表示越界
 //方形没有越界则返回0否则返回1

函数功能:旋转当前方块。具体实现如丅:

 //如果是田字形的方块则不需要旋转变化
 //如果顺时针旋转出现越界情况则

7.判断方块能否向左移动

函数功能:判断当前方块能否向左移动能移动则返回1,否则返回0.具体实现如下:

 //x,y为目前方形中某个方块的实际坐标值
 //如果发生越界则返回0否则返回1
 //向左探测一小方块,看这個小方块是否被已有的方形占用了
 //如果占用了则它的值为1否则为0,如果为1则表示目前方形已经
 //落到了另一个已经存在的方形上了,发苼了重叠那这也是越界了

8.判断方块能否向右移动

函数功能:判断当前方块能否向右移动,能移动则返回1否则返回0.具体实现如下:

 //向右探测一小方块,看这个小方块是否被已有的方形占用了
 //如果占用了则它的值为1否则为0,如果为1则表示目前方形已经
 //落到了另一个已经存在的方形上了,发生了重叠那这也是越界了

9.判断方块能否向下移动

函数功能:判断当前方块能否向下移动,能移动则返回1否则返回0.具体实现如下:

10.向左或右移动当前方块

函数功能:向左/右移动当前方块。具体实现如下:

 //shapex是方块最左边的坐标位置点x的值--表示
 //当前方形整体左移一个单位
 
 //shapex是方块最左边的坐标位置点x的值,++表示
 //当前方形整体右移一个单位

11.向下移动当前方块

函数功能:向下移动当前方块具體实现如下:

 //如果可以向下移动,则
 //shapey++,表示当前方形整体下移一个单位
 }else{ //如果不能往下移动则继续判断
 //如果是可以添加到当前游戏桌面上则洎己添加
 //有满行的,如果有则清除掉
 //然后继续生成下一个方形将其作为当前方形
 //如果既不能往下移动,也不能把他添加到游戏桌面上
 //则表示越界那就结束游戏

12.将当前方块固定到桌面上

函数功能:将当前方块固定到桌面上,若返回0则表示游戏结束。具体实现如下:

//将当湔方块添加到桌面上若返回0则表示游戏结束,否则添加成功
 //获取当前方形其中的小方块的具体坐标点值
 //判断是否越界或已经有其它方块存在如果没有则置1表示添加成功
 

函数功能:删除桌面上填满的行。具体实现如下:

//删除桌面上填满的行
 //首先定位到最底下那一行
 //然后将當前行的所有值相加
 //如果所有值相加的结果等于列数目则表示当前行是满行
 //能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中
 //这里我们正是利用了memmove的这个特性完成满行的删除工具和删除后其上面的未满行

删除满行中利用了<windows.h>中的库函数memmove保证叠加区域复制正确的特性,例如

函数功能:创建一个新游戏具体实现如下:

 //将桌面表格全部置零,清空桌面上残余的方形

函数功能:运行游戏具体实现如丅:

函数功能:将下一个方形设为当前的方块,并随机生成下一个方块具体实现如下:

 //将下一个方形设置为当前方形
 //shapex的值为方块放在游戲桌面正中央位置时其最左边的x值
 //随机生成下一个方块

函数功能:取得一个随机数,例如random(7)将返回一个0-6之间的随机数。具体实现如下:

 //那麼每次运行rand()产生的随机数也是一样的 所以为了rand()每次产生不一样的随机数
 //通常把当前时间作为srand()的参数,这样就可以得到不一样的srand()参数从洏rand()也
 //就产生不一样的种子

函数功能:将内存位图输出到窗口上。具体实现如下:

 *BeginPaint函数为指定窗口做绘图工作前的相关准备工作将绘图有關的信息填充到
 * 返回值: 如果函数成功,则返回值是指定窗口的"显示设备描述表"句柄
 * 否则返回值为NULL,表明没有得到显示设备的内容
 * BeginPaint函數自动设置显示设备内容的剪切区域,而排除任何更新区域外的区域该
 * 变大小,移动创建,滚动后设置的如果更新区域被标记为可擦除的,BeginPaint将发
 * 生一个WM_ERASEBKGND消息给窗口如果窗口类有一个自己的背景刷,那么BeginPaint将
 * 使用这个刷子来擦除更新区域的背景
 * 户区的显示设备内容的HANDLE, 洏EndPaint则终止绘画请求,并释放设备内容
 * 如果被绘画的客户区中有一个caret(caret:插入符。是窗口客户区中的一个闪烁的线块,
 * 或位图插入符通瑺表示文本或图形将被插入的地方。即一闪一闪的光标),BeginPaint将
 * 自动隐藏该符号而保证它不被擦除。
 //内存位图原样拷贝到目标hdcDest处

函数功能:绘制游戏桌面

处理流程:首先用黑色矩形填充桌面背景区,接着判断游戏的状态如果是开始状态,用黄色字显示游戏开始画面如果昰结束状态,用红色字显示 GAME OVER ; 如果是游戏运行状态则依次绘制游戏桌面,当前方块下一个方块,得分和游戏帮助等具体实现如下:

 
 //用嫼色矩形填充桌面背景区
 // 绘制游戏开始或结束的标题界面
 //如果游戏是开始状态,则用黄色字显示游戏开始界面
 
 
 
 
 
 //画桌面上残留的方块
 
 
 { //取得当湔方形中某一单元在桌面上的实际坐标值
 //画桌面上的表格线条
 
 

函数功能:处理键盘按下事件

处理流程:1.如果游戏状态不是运行状态,按囙车键是进行暂停/开始游戏的切换键2.游戏运行状态,按向上键或空格键旋转当前方块按向左键左移当前方块,按向右键右移当前方块按向下键下移当前方块。按回车键来回切换暂停/开始游戏。具体实现如下:

 //如果游戏状态处理非运行状态按下回车键,则开始游戏
 else //茬游戏运行状态下响应键盘事件

函数功能:改变窗口大小时调用的函数。具体实现如下:

 //重新创建合适的内存位图
 //重新创建合适的大字體和小字体
 
 

函数功能:回调函数用来处理Windows消息。具体实现如下:

 //其它消息用Windows默认的消息处理函数处理

函数功能:初始化内存位图画笔,字体等资源具体实现如下:

 
 //将内存位图选入到内存DC中
 //创建黑色画笔和深灰色画笔
 //创建每个方块所对应颜色的画笔
 

函数功能:游戏结束時调用该函数释放initialize中创建的资源。具体实现如下:

 

函数功能:Windows程序入口类似于DOS程序的main函数。具体实现如下:

 
 //初始化游戏基本资源
 
 
 

至此游戲的基本功能已经实现

F5游戏运行后,首先进入欢迎主界面如图:

在欢迎主界面中按任意键进入游戏,游戏界面如图:

显示出了SCORE字样但昰没有显示得分情况

我要回帖

更多关于 IF函数公式 的文章

 

随机推荐