幼儿园算术方法入门

幼儿园算术方法入门,第1张

幼儿园入门算术方法如下:

1、用往前数或往后数的方法,记大数数小数。

2、熟练背诵10以内数的分成和组合,巧妙运用“凑十法”裤运裂和“破十法”。

总之,为了更好地幼小衔接,学前班一般接触了20以内加减法,但也有的幼儿园严格按照教育部不得提前学习小学内容,不教加减法。

实际上孩子上一年级时会学到几种加减法,学前班可以用简单悄镇好记的方法,孩子容易接受。学前班孩子先教他们容易理解和记忆的方法学加减,是为一年级打基础的,如果太复杂就打消了孩子学数学的胡闭兴趣。

建议用上面两种方法即可,第一种方法相对简单,第二种方法孩子只要背熟了10的分成和组合,学起来也不难。

右手代表个位数,左手代表十位数,具体数法如下:

1、把右手的食指伸开“l”,中指伸开“2”,无名指为“3”,小指伸慎拍开“4”,如图所示。

2、把四个手空旅指握起来,伸开大拇指代表5。

3、重新伸出右手的食指,代表6,如图所示宽亏羡。

4、伸开中指、无名指、小拇指,代表7、8、9。

5、把右手把成拳头,伸出左手的食指代表10。

6、再次伸出右手食指,即代表11,如此类推即可。

补充:郑腊敬看来有人不明白,得先建题库文件啊,然后才能输入文件路径捆绑题库,比如我上面的演示中,c:\qs01.txt,你首先要先在c盘创建一个txt文件,然后在里面打字“题目 空格 答案 回车”这样输入。有了库文件程序才能读啊

比如:(你如果自己能修喊慎改我常量里的字符长度,不光数学,语文,英语题库都可以)

在txt文本里保存题库,比如幼儿题目放一个txt,小学题目放一个txt。

程序分两大部分:

1、根据【题库数常量】,提示输入每个题库的类别名称、每个题库文件的路径,生成菜单。

2、用户通过菜单选择,题库类别,输入随机数上限。

3、根据用户输入数字随机抽取一组问题,提问回答并统计正确率。

注意:这里我测试,【题库数常量】qssSize我值设置了2,如想增加题库类别,只要修改该数值即可!。(其他常量我也备注了,有需要自己改)

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <time.h>

#define qsLen 100//问题最大长度

#define ansLen 50//答案最大长度

#define qssSize 2//题库种类数量  我测试只定义了 小学和幼儿 两个问题库,需要自己添加

#define qssNameSize 10//题库名称长度

#define qssPathSize 100//题库路径长度

typedef struct qs

{

    int id//问题编号

    int cont//题库问题数量,只有头结点存储该值

    char qs[qsLen]//问题

    char ans[ansLen]//答案

    struct qs *next

}QS

void newQss(char qssName[][qssNameSize],char qssPath[][qssPathSize])//根据输入,新建问题分类信息

int showMenu(char qssName[][qssNameSize])//显示题库菜单,返回用户选择的题库类别下标

QS *readFile(char *filePath)//读取问题库文件,生成链表,返回头节点

QS *randQs(QS *qsHead,int qsNum)//从题库随机抽取题目,参数:题库头节点、题库总题目数。返回:抽取的题目节点

int main()

{

    int lbNum,qsNum,cnt,i,correct,error

  局敏  char question[qsLen],answer[ansLen],input[ansLen]

    char qssName[qssSize][qssNameSize],qssPath[qssSize][qssPathSize]//qssName: 题库分类名称;qssPath:题库文件路径

    QS *qsHead=NULL,*qsSelect

    srand(time(NULL))

    newQss(qssName,qssPath)

    lbNum=showMenu(qssName)

    printf("\n--开始加载题库--\n")

    qsHead=readFile(qssPath[lbNum])

    qsNum=qsHead->cont

    printf("题库共%d条题目,请输入需要提取的题目数量:",qsNum)

    while(1)

    {

        scanf("%d",&cnt)

        if(cnt>0 && cnt<=qsNum)

            break

    }

    printf("\n--开始从题库中随机抽取%d条问题--\n",cnt)

    correct=0

    error=0

    for(i=0i<cnti++)

    {

        qsSelect=randQs(qsHead,qsNum)

        if(qsSelect!=NULL)

        {

            strcpy(question,qsSelect->qs)

            strcpy(answer,qsSelect->ans)

            printf("第%d题、%s ? 答案:",i+1,question)

            scanf("%s",input)

            if(!strcmp(answer,input))

            {

                printf("回答正确!\n\n")

                correct++

            }

            else

            {

                printf("回答错误!正确答案是%s\n\n",answer)

                error++

            }

        }

    }

    printf("共%d条问题,正确回答%d条,正确率%d%%\n",cnt,correct,correct*100/cnt)

    return 0

}

QS *randQs(QS *qsHead,int qsNum)

{

    int n

    n=rand()%qsNum+1

    while(qsHead->next!=NULL)

    {

        if(qsHead->next->id==n)

            return qsHead->next

        qsHead=qsHead->next

    }

    return NULL

}

void newQss(char qssName[][qssNameSize],char qssPath[][qssPathSize])

{

    int i

    printf("--开始录入题库分类信息--\n")

    for(i=0i<qssSizei++)

    {

        printf("\n请输入题库1的名称及题库文件路径\n名称(不超%d个字符):",qssNameSize)

        scanf("%s",qssName[i])

        printf("路径(不超%d个字符):",qssPathSize)

        scanf("%s",qssPath[i])

    }

}

int showMenu(char qssName[][qssNameSize])

{

    int i

    printf("\n当前题库分类为:\n")

    for(i=0i<qssSizei++)

        printf("%d、 %s\n",i+1,qssName[i])

    printf("请选择你要提取的题库类别(输入数字):")

    scanf("%d",&i)

    return i-1

}

QS *readFile(char *filePath)

{

    FILE *fp

    char qsSave[qsLen],ansSave[ansLen]

    QS *qsHead=NULL,*qsTail=NULL

    if((fp=fopen(filePath,"rt+"))==NULL)

    {

        printf("Cannot open file strike any key exit!")

        return NULL

    }

    qsHead=(QS *)malloc(sizeof(QS))

    qsHead->next=NULL

    qsHead->cont=0

    while(fscanf(fp,"%s %s",qsSave,ansSave)!=-1)

    {

        qsHead->cont++

        QS *qsNew=(QS *)malloc(sizeof(QS))

        qsNew->next=NULL

        qsNew->id=qsHead->cont

        strcpy(qsNew->qs,qsSave)

        strcpy(qsNew->ans,ansSave)

        if(qsHead->next==NULL)

            qsHead->next=qsNew

        else

            qsTail->next=qsNew

        qsTail=qsNew

    }

    return qsHead

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12302925.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存