nbhkdz.com冰点文库

NOIP竞赛培训第一讲

时间:2016-10-06


Concept: I/O
?

什么是 I/O?
? Input & Output (输入与输出) ? printf, scanf, putchar, getchar… ? <stdio.h>

字符I/O ? 格式化I/O ? 文件I/O
?

Review:get

char & putchar
?

字符I/O

Char c; ? c=getchar(); ? putchar(c); ? putchar(?\n?);
?

Review:printf & scanf
格式化I/O ? F=format
? ? ? ? ? ? ?

char s[]=“abcdefghijklmn” printf (“%s\n”,s); printf (“%.5s\n”,s); printf (“%30s\n”,s); printf (“%20.5s\n”,s); printf (“%-20.5s\n”,s);

Exercise:陶陶摘苹果
?

陶陶家的院子里有一棵苹果树,每到秋天树上就会结出10个苹果。苹果成熟的时候,陶陶就会跑去 摘苹果。陶陶有个30厘米高的板凳,当她不能直接用手摘到苹果的时候,就会踩到板凳上再试试。 现在已知10个苹果到地面的高度,以及陶陶把手伸直的时候能够达到的最大高度,请帮陶陶算一下 她能够摘到的苹果的数目。假设她碰到苹果,苹果就会掉下来。 【输入】输入包括两行数据。第一行包含10个100到200之间(包括100和200)的整数(以厘米为 单位)分别表示10个苹果到地面的高度,两个相邻的整数之间用一个空格隔开。第二行只包括一个 100到120之间(包含100和120)的整数(以厘米为单位),表示陶陶把手伸直的时候能够达到的最 大高度。

?

?

?

【输出】输出包括一行,这一行只包含一个整数,表示陶陶能够摘到的苹果的数目。

? ? ? ? ?

【样例输入】 100 200 150 140 129 134 167 198 200 111 110 【样例输出】 5

Ans
? ? ? ? ? ? ?

#include <stdio.h> int apples[10]; int main(void) { int ans; int i, h; for(i = 0; i < 10; i++){ scanf("%i", &apples[i]); } scanf("%d", &h); h += 30; for(i = ans = 0; i < 10; i++){ if(apples[i] <= h){ ans++; } } printf("%i\n", ans); return 0; }

?
? ? ? ? ?

?
? ? ? ? ?

But……
?

?

【输入文件】 输入文件apple.in包括两行数据。第一行包含10个100 到200之间(包括100和200)的整数(以厘米为单位) 分别表示10个苹果到地面的高度,两个相邻的整数之 间用一个空格隔开。第二行只包括一个100到120之间 (包含100和120)的整数(以厘米为单位),表示陶 陶把手伸直的时候能够达到的最大高度。

? ?

【输出文件】 输出文件apple.out包括一行,这一行只包含一个整数, 表示陶陶能够摘到的苹果的数目。

New!文件输入输出操作
将I/O重定向到文件中 ? 读写文件操作——写作业
?
? 打开文件——打开作业本

? 读取数据——读题目
? 运算——运算 ? 输出数据——写解答

? 关闭文件——关上作业本

New!打开文件
? ? ?

文件的结构类型FILE fopen(); #include<stdio.h> FILE *input,*output; Input=fopen(“apple.in”,”r”); Output=fopen(“apple.out”,”w”); If (input==NULL) printf(“Bi! Error!\n”); Else //读取数据

?
? ? ? ? ? ?

New!读取数据&输出数据
?

getc, putc

c=getc(input); ? putc(?\n?, output);
?

New!关闭文件
fclose(); ? 非常重要!!!
?

fclose(input); ? fclose(output);
?

Exercise:拷贝文件
输入:需要拷贝的文件,拷贝文件的输出 名称 ? 操作 :拷贝文件!
?

Ans
#include<stdio.h> int main(void) { FILE *input, *output; char c; input=fopen(“1.in”,”r”); output=fopen(“1.out”.”w”); while((c=getc(input))!=EOF) putc(output,c); fclose(input); fclose(output); }

New:fscanf & fprintf
fscanf(input,”%i”,&a); ? fprintf(output,”%i”,a);
?

Focus! Two Methods
? ? ? ? ? ? ? ?

Method 1:

?

Method 2:
freopen(“apple.in”,”r”,st din); freopen(“apple.out”,”w”, stdout); scanf(”%i”,&a); printf(”%i”,a); fclose(stdin); fclose(stdout);

FILE *input,*output; ? input=fopen(“apple.in”,”r ”); ? output=fopen(“apple.out ”,”w”); ? fscanf(input,”%i”,&a); ? fprintf(output,”%i”,a); ? fclose(input); ? fclose(output);

End


高中信息学奥林匹克竞赛培训策略研究

一些不负责的学校甚至利用大量课时进行 Pascal 语言的讲 授, 不仅使学生在课堂...2.做好培训的组织与选拔 信息学奥林匹克竞赛分为 NOIP、NOI、IOI,其主要目的...

关于参加《NOIP2016全国青少年信息学(计算机)奥林区克...

关于参加《NOIP2016全国青少年信息学(计算机)奥林区克...为早期发现和培养优秀青少 年科技后备人才提供一条...3、对获奖学生,省竞赛委员会将集中培训,从中选拔出...

信息学奥赛训练计划(袁森龙)

使学生具备参加全国信息学奥林匹克竞赛分区联赛 NOIP (初赛、 复赛) 的能力。 ...第三阶段:初赛及复赛强化培训从 2017 年 9 月第一周到 11 月第三周培训...

信息学奥赛基础知识习题NOIP(答案版)

noip第十五届(2009年)信息... 12页 1财富值 信息学奥赛基础知识习题1 13页 2财富值喜欢此文档的还喜欢 信息学奥林匹克竞赛培训教... 80页 免费 (信息学奥...

信息学竞赛辅导资料

信息学竞赛辅导资料_学科竞赛_高中教育_教育专区。信息学奥赛。。第...NOIP 是同一时间在全国各个省份同时开展的比赛,1995 年开始举办第一届。只有在...

信息竞赛推荐书籍

3、《学习指导》(推荐指数:5 颗星) 刘汝佳著,《算法艺术与信息学竞赛》的辅导...2、除此之外 Vijos 也是一个不错的题库,有很多中文题. 3、国内广受 NOIP ...

NOIP普及组复赛辅导-枚举专题

百度文库 教育专区 初中教育 学科竞赛上传文档...NOIP普及组复赛辅导-枚举专题,适用于新入门的学生辅导...3 枚举法总结:枚举法是一种比较笨拙的算法,因为它...

NOIP培训教程dp1

在华罗庚先生的家乡江苏金坛,组织了一场别 开生面的数学智力竞赛活动,你的好友...NOIP第四节 14页 免费 NOIP初赛辅导 69页 1下载券 NOIP初赛复习 53页 1下载...

青少年信息学奥林匹克初级竞赛辅导练习题

青少年信息学奥林匹克初级竞赛辅导练习题_学科竞赛_小学教育_教育专区。第一题(p...P28 练习 [例2]报数游戏(NOIP-TJ-2006小学组复赛题)。(p30) 小朋友都喜欢...

信息学奥赛(NOIP)必看经典书目汇总

信息学奥赛(NOIP)必看经典书目汇总_学科竞赛_高中教育_教育专区。信息学奥赛(...《全国信息学奥林匹克联赛培训教程(一) 》 (推荐指数:5 颗星) 传说中的黄书...