幼儿园入门算术方法如下:
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
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)