扫雷的分析与实现——C语言

扫雷作为一款经典游戏,为大家所熟知。今天我使用C语言来编写一个简单的扫雷程序。

主要功能有

1.第一次下子不被炸死;
2.下子后显示周围布雷数;

分析游戏及功能

首先可以将扫雷的游戏界面看做一个二维数组;然后有限的雷随机排布在这个二维数组中,玩家通过输入坐标来确定该坐标对应的二维数组坐标是否是雷,若不是则显示周围布雷数,这时考虑坐标如果在数组的中间则少显示周围8个坐标布雷情况,而在数组边缘则小于8。因此我在创建数组时创建一个比所需数大2行2列。将所需数组视为中间数组即可;如图:

代码创建

创建test.c,game.c和game.h三个文件

1.创建主函数,打印菜单用do,whlie语句实现基选择功能;

代码如下:

int main()
{
    srand((unsigned int)time(NULL));//产生随机数生成器
    int input = 0;
    do
    {
        muen();
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            game();
            break;
        case 0:
            printf("退出游戏\n");
            break;
        default:
            printf("输入错误,重新输入\n");
            break;
        }
    } while (input);
    system("pause");
    return 0;
}

2.在game.c中先完成菜单,数组的创建,以及玩家的界面,和布雷的界面

代码如下;

void muen()
{
    printf("*******************************\n");
    printf("*****1.play       0.exit*******\n");
    printf("*******************************\n");
}

void init_mine()//初始化两个棋盘
{
    int i = 0;
    int j = 0;
    for (int i = 0; i < row; i++)
    {
        for (j = 0; j < col; j++)
        {
            show_mine[i][j] = ‘*‘;
            real_mine[i][j] = ‘0‘;
        }
    }
}

void print_player()//打印玩家棋盘
{
    int i = 0;
    int j = 0;
    printf("0  ");
    for (i = 1; i <row - 1; i++)
    {
        printf("%d ", i);
    }
    printf("\n");
    for (i = 1; i <row - 2; i++)
    {
        printf("%d  ", i);
        for (j = 1; j < col - 1; j++)
        {
            printf("%c ", show_mine[i][j]);//玩家棋盘数组
        }
        printf("\n");
    }
    printf("10 ");//开始打印最后一行
    for (i = 1; i < row - 1; i++)
    {
        printf("%c ", show_mine[10][i]);
    }
    printf("\n");
}

void print_mine()//打印设计者棋盘
{
    int i = 0;
    int j = 0;
    printf("0  ");
    for (i = 1; i <row - 1; i++)
    {
        printf("%d ", i);
    }
    printf("\n");
    for (i = 1; i <row - 2; i++)
    {
        printf("%d  ", i);
        for (j = 1; j < col - 1; j++)
        {
            printf("%c ", real_mine[i][j]);
        }
        printf("\n");
    }
    printf("10 ");//开始打印最后一行
    for (i = 1; i < row - 1; i++)
    {
        printf("%c ", real_mine[10][i]);
    }
    printf("\n");
}

效果如图:

3.完成布雷函数以及扫雷函数

代码如下:

void set_mine()        //给设计者棋盘布雷
{
    int x = 0;
    int y = 0;
    int count = COUNT; //雷总数
    while (count)      //雷布完后跳出循环
    {
        int x = rand() % 10 + 1;     //产生1到10的随机数,在数组下标为1到10的范围内布雷
        int y = rand() % 10 + 1;     //产生1到10的随机数,在数组下标为1到10的范围内布雷
        if (real_mine[x][y] == ‘0‘)  //找不是雷的地方布雷
        {
            real_mine[x][y] = ‘1‘;
            count--;
        }
    }
}
int sweep_mine()//扫雷函数,踩到雷返回1,没有踩到雷返回0
{
    int x = 0;
    int y = 0;
    int count = 0;
    printf("输入坐标扫雷\n");
    scanf("%d%d", &x, &y);
    if ((x >= 1 && x <= 10) && (y >= 1 && y <= 10))//判断输入坐标是否有误,输入错误重新输入
    {
        if (real_mine[x][y] == ‘0‘)//没踩到雷
        {
            char ch = count_mine(x, y);
            show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
            open_mine(x, y);
            if (count_show_mine() == COUNT)//判断剩余未知区域的个数,个数为雷数时玩家赢
            {
                return 0;
            }
        }
        else if (real_mine[x][y] == ‘1‘)//踩到雷
        {
            return 1;
        }
    }
    else
    {
        printf("输入错误重新输入\n");
    }
    return 0;//没踩到雷
}

4.完成防止第一步被炸死的函数

代码如下:

void safe_mine()//避免第一次炸死
{
    int x = 0;
    int y = 0;
    char ch = 0;
    int count = 0;
    int ret = 1;
    printf("游戏开始\n");
    printf("输入坐标扫雷\n");
    while (1)
    {
        scanf("%d%d", &x, &y);//只能输入1到10,输入错误重新输入
        if ((x >= 1 && x <= 10) && (y >= 1 && y <= 10))//判断输入坐标是否有误
        {
            if (real_mine[x][y] == ‘1‘)//第一次踩到雷后补救
            {
                real_mine[x][y] = ‘0‘;
                char ch = count_mine(x, y);
                show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
                open_mine(x, y);
                while (ret)//在其余有空的地方设置一个雷
                {
                    int x = rand() % 10 + 1;//产生1到10的随机数,在数组下标为1到10的范围内布雷
                    int y = rand() % 10 + 1;//产生1到10的随机数,在数组下标为1到10的范围内布雷
                    if (real_mine[x][y] == ‘0‘)//找不是雷的地方布雷
                    {
                        real_mine[x][y] = ‘1‘;
                        ret--;
                        break;
                    }
                }break;//跳出此函数
            }
            if (real_mine[x][y] == ‘0‘)
            {
                char ch = count_mine(x, y);
                show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
                open_mine(x, y);
                break;
            }
        }
        else//坐标错误
        {
            printf("输入错误重新输入\n");
        }
    }
}

5.完成检测周围雷数并显示函数

int count_mine(int x, int y)//检测周围8个区域雷的个数
{
    int count = 0;
    if (real_mine[x - 1][y - 1] == ‘1‘)
        count++;
    if (real_mine[x - 1][y] == ‘1‘)
        count++;
    if (real_mine[x - 1][y + 1] == ‘1‘)
        count++;
    if (real_mine[x][y - 1] == ‘1‘)
        count++;
    if (real_mine[x][y + 1] == ‘1‘)
        count++;
    if (real_mine[x + 1][y - 1] == ‘1‘)
        count++;
    if (real_mine[x + 1][y] == ‘1‘)
        count++;
    if (real_mine[x + 1][y + 1] == ‘1‘)
        count++;
    return count;
}

void open_mine(int x, int y)//坐标周围展开函数
{
    if (real_mine[x - 1][y - 1] == ‘0‘)
    {
        show_mine[x - 1][y - 1] = count_mine(x - 1, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x - 1][y] == ‘0‘)
    {
        show_mine[x - 1][y] = count_mine(x - 1, y) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x - 1][y + 1] == ‘0‘)
    {
        show_mine[x - 1][y + 1] = count_mine(x - 1, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x][y - 1] == ‘0‘)
    {
        show_mine[x][y - 1] = count_mine(x, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x][y + 1] == ‘0‘)
    {
        show_mine[x][y + 1] = count_mine(x, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y - 1] == ‘0‘)
    {
        show_mine[x + 1][y - 1] = count_mine(x + 1, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y] == ‘0‘)
    {
        show_mine[x + 1][y] = count_mine(x + 1, y) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y + 1] == ‘0‘)
    {
        show_mine[x + 1][y + 1] = count_mine(x + 1, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
}

6.最后完成判断玩家赢的函数

代码如下;

int count_show_mine()//判断剩余未知区域的个数,个数为雷数时玩家赢
{
    int count = 0;
    int i = 0;
    int j = 0;
    for (i = 1; i <= row - 2; i++)
    {
        for (j = 1; j <= col - 2; j++)
        {
            if (show_mine[i][j] == ‘*‘)
            {
                count++;
            }
        }
    }
    return count;
}

最后运行测试

查看第一是否可以炸死(根据布雷图,输入有雷坐标未被炸死):

第二步输入有雷坐标:

判断玩家赢;

test.c代码

#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
double  start, finish;
void game()
{
    int ret = 0;
    init_mine();             //初始化玩家棋盘和设计者棋盘
    set_mine();              //给设计者棋盘布雷
    print_mine();            //打印设计者棋盘(可不打印)
    printf("\n");
    print_player();          //打印玩家棋盘
    start = clock();
    safe_mine();             //避免第一次被炸死

    if (count_show_mine() == COUNT)//一步就赢的情况
    {
        print_mine();
        printf("玩家赢!\n\n");
        return;
     }
    print_player();
    while (1)//循环扫雷
    {
        int ret = sweep_mine();//扫雷,踩到雷返回1,没有踩到雷返回0
        if (count_show_mine() == COUNT)//若玩家棋盘的‘*‘个数为雷数时,扫雷完成,游戏胜利
        {
            print_mine();    //打印设计者棋盘
            printf("玩家赢!\n\n");
            finish = clock();//取结束时间
            printf("用时%d 秒\n", (int)(finish - start) / CLOCKS_PER_SEC);
            break;
        }
        if (ret)//判断是否踩到雷
        {
            printf("被雷炸死\t");
            finish = clock();//取结束时间
            printf("用时%d 秒\n", (int)(finish - start) / CLOCKS_PER_SEC);
            print_mine();//打印设计者雷阵查看雷的分布
            break;
        }
        print_player();//打印玩家棋盘
    }
}

int main()
{
    srand((unsigned int)time(NULL));//产生随机数生成器
    int input = 0;
    do
    {
        muen();
        scanf("%d", &input);
        switch (input)
        {
        case 1:
            game();
            break;
        case 0:
            printf("退出游戏\n");
            break;
        default:
            printf("输入错误,重新输入\n");
            break;
        }
    } while (input);//循环玩游戏
    system("pause");
    return 0;
}

game.c代码

#define _CRT_SECURE_NO_WARNINGS 1
#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
char show_mine[row][col] = { 0 };
char real_mine[row][col] = { 0 };

void muen()
{
    printf("*******************************\n");
    printf("*****1.play       0.exit*******\n");
    printf("*******************************\n");
}

void init_mine()//初始化两个棋盘
{
    int i = 0;
    int j = 0;
    for (int i = 0; i < row; i++)
    {
        for (j = 0; j < col; j++)
        {
            show_mine[i][j] = ‘*‘;
            real_mine[i][j] = ‘0‘;
        }
    }
}

void print_player()//打印玩家棋盘
{
    int i = 0;
    int j = 0;
    printf("0  ");
    for (i = 1; i <row - 1; i++)
    {
        printf("%d ", i);//打印横标(0--10)
    }
    printf("\n");
    for (i = 1; i <row - 2; i++)//打印竖标(1--10)
    {
        printf("%d  ", i);
        for (j = 1; j < col - 1; j++)
        {
            printf("%c ", show_mine[i][j]);//玩家棋盘数组
        }
        printf("\n");
    }
    printf("10 ");//开始打印最后一行
    for (i = 1; i < row - 1; i++)
    {
        printf("%c ", show_mine[10][i]);
    }
    printf("\n");
}

void print_mine()//打印设计者棋盘
{
    int i = 0;
    int j = 0;
    printf("0  ");
    for (i = 1; i <row - 1; i++)
    {
        printf("%d ", i);
    }
    printf("\n");
    for (i = 1; i <row - 2; i++)
    {
        printf("%d  ", i);
        for (j = 1; j < col - 1; j++)
        {
            printf("%c ", real_mine[i][j]);
        }
        printf("\n");
    }
    printf("10 ");//开始打印最后一行
    for (i = 1; i < row - 1; i++)
    {
        printf("%c ", real_mine[10][i]);
    }
    printf("\n");
}

void set_mine()        //给设计者棋盘布雷
{
    int x = 0;
    int y = 0;
    int count = COUNT; //雷总数
    while (count)      //雷布完后跳出循环
    {
        int x = rand() % 10 + 1;     //产生1到10的随机数,在数组下标为1到10的范围内布雷
        int y = rand() % 10 + 1;     //产生1到10的随机数,在数组下标为1到10的范围内布雷
        if (real_mine[x][y] == ‘0‘)  //找不是雷的地方布雷
        {
            real_mine[x][y] = ‘1‘;
            count--;
        }
    }
}
int sweep_mine()//扫雷函数,踩到雷返回1,没有踩到雷返回0
{
    int x = 0;
    int y = 0;
    int count = 0;
    printf("输入坐标扫雷\n");
    scanf("%d%d", &x, &y);
    if ((x >= 1 && x <= 10) && (y >= 1 && y <= 10))//判断输入坐标是否有误,输入错误重新输入
    {
        if (real_mine[x][y] == ‘0‘)//没踩到雷
        {
            char ch = count_mine(x, y);
            show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
            open_mine(x, y);
            if (count_show_mine() == COUNT)//判断剩余未知区域的个数,个数为雷数时玩家赢
            {
                return 0;
            }
        }
        else if (real_mine[x][y] == ‘1‘)//踩到雷
        {
            return 1;
        }
    }
    else
    {
        printf("输入错误重新输入\n");
    }
    return 0;//没踩到雷
}

void safe_mine()//避免第一次炸死
{
    int x = 0;
    int y = 0;
    char ch = 0;
    int count = 0;
    int ret = 1;
    printf("游戏开始\n");
    printf("输入坐标扫雷\n");
    while (1)
    {
        scanf("%d%d", &x, &y);//只能输入1到10,输入错误重新输入
        if ((x >= 1 && x <= 10) && (y >= 1 && y <= 10))//判断输入坐标是否有误
        {
            if (real_mine[x][y] == ‘1‘)//第一次踩到雷后补救
            {
                real_mine[x][y] = ‘0‘;
                char ch = count_mine(x, y);
                show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
                open_mine(x, y);
                while (ret)//在其余有空的地方设置一个雷
                {
                    int x = rand() % 10 + 1;//产生1到10的随机数,在数组下标为1到10的范围内布雷
                    int y = rand() % 10 + 1;//产生1到10的随机数,在数组下标为1到10的范围内布雷
                    if (real_mine[x][y] == ‘0‘)//找不是雷的地方布雷
                    {
                        real_mine[x][y] = ‘1‘;
                        ret--;
                        break;
                    }
                }break;//跳出此函数
            }
            if (real_mine[x][y] == ‘0‘)
            {
                char ch = count_mine(x, y);
                show_mine[x][y] = ch + ‘0‘;//数字对应的ASCII值和数字字符对应的ASCII值相差48,即‘0‘的ASCII值
                open_mine(x, y);
                break;
            }
        }
        else//坐标错误
        {
            printf("输入错误重新输入\n");
        }
    }
}

int count_mine(int x, int y)//检测周围8个区域雷的个数
{
    int count = 0;
    if (real_mine[x - 1][y - 1] == ‘1‘)
        count++;
    if (real_mine[x - 1][y] == ‘1‘)
        count++;
    if (real_mine[x - 1][y + 1] == ‘1‘)
        count++;
    if (real_mine[x][y - 1] == ‘1‘)
        count++;
    if (real_mine[x][y + 1] == ‘1‘)
        count++;
    if (real_mine[x + 1][y - 1] == ‘1‘)
        count++;
    if (real_mine[x + 1][y] == ‘1‘)
        count++;
    if (real_mine[x + 1][y + 1] == ‘1‘)
        count++;
    return count;
}

void open_mine(int x, int y)//坐标周围展开函数
{
    if (real_mine[x - 1][y - 1] == ‘0‘)
    {
        show_mine[x - 1][y - 1] = count_mine(x - 1, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x - 1][y] == ‘0‘)
    {
        show_mine[x - 1][y] = count_mine(x - 1, y) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x - 1][y + 1] == ‘0‘)
    {
        show_mine[x - 1][y + 1] = count_mine(x - 1, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x][y - 1] == ‘0‘)
    {
        show_mine[x][y - 1] = count_mine(x, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x][y + 1] == ‘0‘)
    {
        show_mine[x][y + 1] = count_mine(x, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y - 1] == ‘0‘)
    {
        show_mine[x + 1][y - 1] = count_mine(x + 1, y - 1) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y] == ‘0‘)
    {
        show_mine[x + 1][y] = count_mine(x + 1, y) + ‘0‘;//显示该坐标周围雷数
    }
    if (real_mine[x + 1][y + 1] == ‘0‘)
    {
        show_mine[x + 1][y + 1] = count_mine(x + 1, y + 1) + ‘0‘;//显示该坐标周围雷数
    }
}

int count_show_mine()//判断剩余未知区域的个数,个数为雷数时玩家赢
{
    int count = 0;
    int i = 0;
    int j = 0;
    for (i = 1; i <= row - 2; i++)
    {
        for (j = 1; j <= col - 2; j++)
        {
            if (show_mine[i][j] == ‘*‘)
            {
                count++;
            }
        }
    }
    return count;
}

game.h代码

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<time.h>

#define row 12
#define col 12
#define COUNT 10//棋盘中雷的总数
extern char real_mine[row][col];//布雷数组

void muen();           //菜单函数
void init_mine();      //初始化数组函数
void print_player();   //打印玩家棋盘
void print_mine();     //打印设计者棋盘
void set_mine();       //布雷函数
int count_mine();      //统计周围雷的个数
void safe_mine();      //避免第一次被雷炸死的函数
int  sweep_mine();     //扫雷函数
void open_mine(int x, int y);//展开函数
int count_show_mine(); //判断玩家棋盘剩余未知区域的个数

原文地址:https://blog.51cto.com/14441430/2424656

时间: 2024-10-11 22:13:35

扫雷的分析与实现——C语言的相关文章

[Abp 源码分析]十三、多语言(本地化)处理

0.简介 如果你所开发的需要走向世界的话,那么肯定需要针对每一个用户进行不同的本地化处理,有可能你的客户在日本,需要使用日语作为显示文本,也有可能你的客户在美国,需要使用英语作为显示文本.如果你还是一样的写死错误信息,或者描述信息,那么就无法做到多语言适配. Abp 框架本身提供了一套多语言机制来帮助我们实现本地化,基本思路是 Abp 本身维护一个键值对集合.只需要将展示给客户的文字信息处都使用一个语言 Key 来进行填充,当用户登录系统之后,会取得当前用户的区域文化信息进行文本渲染. 0.1

三子棋分析与实现——C语言

三子棋作为一款经典的小游戏,对于初学C语言的我们如果 可以熟练了解并可以实现其游戏功能,则对于以后更系统的学习C语言有很好帮助.下来我分享一下我在编程时的感悟和代码 首先介绍一下三子棋规则:只要将自己的棋连成一条线(行,列,斜线),即为赢如图: 先根据图和玩法大致有个思路: 1.我们可以将棋盘看做是一个三行三列的二维数组,且每行每列用线隔开以便区分2.分为电脑下棋和玩家下棋(电脑先下和玩家先下)3.判断输赢(玩家赢,电脑赢和平局) 大致思路即为上面分析,下面开始写代码: 创建tset.c,gam

分析一段XAML语言代码

分析WPF的一段xaml代码: 1 <UserControl x:Class="UserControl1" 2 xmlns="..." 3 xmlns:x="..." 4 xmlns:mc="..." 5 xmlns:d="..." 6 xmlns:local="clr-namespace:WpfApp3" 7 mc:Ignorable="d" 8 d:Desi

C语言新手写扫雷攻略1

工欲善其事,必先利其器,首先要准备好开发环境,既然是C语言,那就不是WinAPI的扫雷,就是纯的C语言开发,但是以前的C都是TC开发的,现在用肯定是过时很久了,但是也是有解决办法的,某些大神开发出EasyX这个库,基本上还原了TC的函数,就可以在各种IDE下使用了,下面是下载地址和帮助,帮助里面有所有函数的调用方法 http://www.easyx.cn/ 下载解压好后将include 和 lib 文件夹复制到你的VC对应安装的文件夹里覆盖就可以使用了,从vc++6.0到vs2013都可以使用

C语言链表的来源分析

C语言中的链表是重点,也是难点,而且意义非凡.对链表的的抽象和恐惧是源于对它的来龙去脉的不明白.所以很有必要对它的发展渊源做透彻分析. 链表的单位是节点,而节点源于复合数据类型:结构体: 节点和结构体的区别就是看是否有指针域,目的就是想找到下一个节点: 结构体形如: struct Ghost { char name[30]; int age; int height; char addr[30]; }; 节点形如: struct Ghost { char name[30]; int age; in

C++写一个简单的解析器(分析C语言)

该方案实现了一个分析C语言的词法分析+解析. 注意: 1.简单语法,部分秕.它可以在本文法的基础上进行扩展,此过程使用自上而下LL(1)语法. 2.自己主动能达到求First 集和 Follow 集. 3.处终结符外(有些硬编码的成分),终结符的文法能够自己定义,也就是说读者能够自己定义文法. 4.为方便理解.C语言的文法描写叙述写成中文. 5.程序将词法分析和语法分析结合起来.词法分析的结果作为语法分析的输入. 6.终于结果在控制台显示的有:词法分析.First集.Follow集.Select

C++应用程序性能优化(三)——C++语言特性性能分析

C++应用程序性能优化(三)--C++语言特性性能分析 一.C++语言特性性能分析简介 通常大多数开发人员认为,汇编语言和C语言比较适合编写对性能要求非常高的程序,C++语言主要适用于编写复杂度非常高但性能要求并不是很高的程序.因为大多数开发人员认为,C++语言设计时因为考虑到支持多种编程模式(如面向对象编程和范型编程)以及异常处理等,从而引入了太多新的语言特性.新的语言特性往往使得C++编译器在编译程序时插入了很多额外的代码,会导致最终生成的二进制代码体积膨胀,而且执行速度下降.但事实并非如此

分析函数调用关系图(call graph)的几种方法

分析函数调用关系图(call graph)的几种方法 绘制函数调用关系图对理解大型程序大有帮助.我想大家都有过一边读源码(并在头脑中维护一个调用栈),一边在纸上画函数调用关系,然后整理成图的经历.如果运气好一点,借助调试器的单步跟踪功能和call stack窗口,能节约一些脑力.不过如果要分析的是脚本语言的代码,那多半只好老老实实用第一种方法了.如果在读代码之前,手边就有一份调用图,岂不妙哉?下面举出我知道的几种免费的分析C/C++函数调用关系的工具. 函数调用关系图(call graph)是图

基于R语言的数据分析和挖掘方法总结——均值检验

2.1 单组样本均值t检验(One-sample t-test) 2.1.1 方法简介 t检验,又称学生t(student t)检验,是由英国统计学家戈斯特(William Sealy Gosset, 1876-1937)所提出,student则是他的笔名.t检验是一种检验总体均值的统计方法,当数据中仅含单组样本且样本数较大时(通常样本个数≧30的样本可视为样本数较大),可用这种方法来检验总体均值是否大于.小于或等于某一特定数值.当数据中仅含单组样本但样本数较小时(通常样本个数<30的样本可视为