nbhkdz.com冰点文库

NOIP竞赛培训第一讲


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


竞赛辅导教案

noip初赛noip初赛隐藏>> 信息学奥林匹克竞赛辅导讲稿 目第一讲 第二讲 第三讲 第四讲 第五讲 第六讲 第七讲 第八讲 第九讲 第十讲 第十一讲 第十二讲 ...

NOIP初赛模拟训练1

NOIP初赛模拟训练1_财会/金融考试_资格考试/认证_教育专区。一、选择 1 个正确...(2*7+3*5) ; 第 1 题(14 分) ,以下程序是将一组整数按从小到大的...

全国信息学奥林匹克竞赛初级指导教师培训班

全国信息学奥林匹克竞赛初级 初级指导教师培训班 初级 教学大纲一、宗旨 中国...(2 小时) 第六天 授课内容 上午:近几年 NOIP 普及组复赛试题分析 (8 小时)...

edu_ecologychuanke1477646173

有语言基础的学生NOIP竞赛提高组各阶段的课程,无论从哪起步,都可达到预定的高度。视频教程,幼狮精英学馆全套教学,在线学习初中科学课程,2016年NOIP竞赛算法一对一...

NOIP培训讲义1

NOIPNOIP隐藏>> 第一NOIP 培训简介培训目的 此培训班是为了帮助同学参加信息学奥林匹克竞赛(简称 OI) ,培养一些高素质的信息 技术人才,激励对计算机有热爱的同...

在信息学奥赛辅导中我的几点做法

辅导完这些就到了每年的十一月份参加 NOIP(全国奥林匹克信息学竞赛联赛) 。二、注重自主性学习,辅导小组的形式多样性 信息学竞赛知识不是我们上课讲给学生的 word...

信息学奥林匹克竞赛普及培训

1. 竞赛的语言环境 .本培训针对竞赛语言之一的 Free Pascal 进行。计算机操作...(http://www.noi.cn) ,单击 NOIP2008 栏目下的超链 接“2008 竞赛评测系统...

NOIP竞赛基础知识

noip基础知识 33页 免费 第九届教职工趣味运动会竞... 3页 免费 信息学奥林匹克竞赛培训教... 80页 免费如要投诉违规内容,请到百度文库投诉中心;如要提出功能...

信息学竞赛辅导资料

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

noip普及组复赛入门训练1答案

noip普及组复赛入门训练1答案_学科竞赛_初中教育_教育专区。PASCAL 复习 2 1. 字符统计(文件名 ZFTJ.PAS) 读入一组字符,以“?”作为结束标志,统计其中元音字母...