杭电acm初学者.ppt
合集下载
C语言速成与ACM入门PPT课件
• scanf的格式为 scanf("……“, &a,……);
• 例如
• int a;
• scanf("%d",&a);
• %以及后面的内容为需要代换的内容,不同的字母有不同的含义:
• %d:一个整数
• %f:一个小数
• %c:一个字符
• %s:一个字符串(遇到空格与回车的时候结束)
• %%:一个百分号
第25页/共36页
Page 25
初学者易犯的错误
• 题目:输入两个数,输出该两个数的差 • 样例输入:12 3 • 样例输出:9
• #include<iostream> using namespace std;
int main(){ int a,b; cout << "Please input the numbers:"; cin>>a>>b; cout << "The answer is:" << a-b << endl; return 0;
• #include<iostream> using namespace std;
int main(){ cin >> a>>b; cout <<a-b<<endl; return 0;
}
没有endl会返回PE
第27页/共36页
Page 27
ACM常用技巧
• 一般而言,C++的cin与cout速度上会比C语言的scanf和printf慢很多,所以我们推荐使用scanf和printf 而不是cin cout
杭电acm初学者课件
单击此处添加小标题
1
上面的程序有什么问题?
单击此处添加小标题
2
*
*
本类输入解决方案:
C语法:
while(scanf("%d",&n) && n!=0 ) { .. }
01
C++语法:
while( cin >> n && n != 0 ) { .. }
02
*
*
输入_第四类:
以上几种情况的组合
1095源代码
#2022
*
*
解决办法:
{ . ut << ans << endl << endl; }
C++语法:
02
{ .. printf("%d\n\n",ans); }
C语法:
01
*
*
输出_第三类:
一个Input Block对应一个Output Block,Output Block之间有空行。 参见:HDOJ_1096
*
*
单击此处添加副标题
计算机学院 刘春英
ACM 程序设计
*
*
单击此处添加副标题
ACM入门
第一讲
*
*
单击此处添加副标题
202X
初识ACM
*
*
What is ACM ?
ACM (Association for Computing Machinery) 成立于计算机诞生次年,是目前计算机学界中历史最悠久、最具权威性的组织…
*
*
输入_第五类:
202X
1
上面的程序有什么问题?
单击此处添加小标题
2
*
*
本类输入解决方案:
C语法:
while(scanf("%d",&n) && n!=0 ) { .. }
01
C++语法:
while( cin >> n && n != 0 ) { .. }
02
*
*
输入_第四类:
以上几种情况的组合
1095源代码
#2022
*
*
解决办法:
{ . ut << ans << endl << endl; }
C++语法:
02
{ .. printf("%d\n\n",ans); }
C语法:
01
*
*
输出_第三类:
一个Input Block对应一个Output Block,Output Block之间有空行。 参见:HDOJ_1096
*
*
单击此处添加副标题
计算机学院 刘春英
ACM 程序设计
*
*
单击此处添加副标题
ACM入门
第一讲
*
*
单击此处添加副标题
202X
初识ACM
*
*
What is ACM ?
ACM (Association for Computing Machinery) 成立于计算机诞生次年,是目前计算机学界中历史最悠久、最具权威性的组织…
*
*
输入_第五类:
202X
(lecture_01)初识ACM_20070925_simplePPT精品文档71页
20 08.01.2020
ACM题目特点:
由于ACM竞赛题目的输入数据和输出数 据一般有多组(不定),并且格式多种 多样,所以,如何处理题目的输入输出 是对大家的一项最基本的要求。这也是 困扰初学者的一大问题。
下面,分类介绍:
21 08.01.2020
先看一个超级简单的题目:
/showproblem.php?pid=108 9
Run Time Error -- 程序运行过程中出现非正常中断。
Time Limit Exceeded
-- 运行超过时限还没有得到输出结果。
Wrong Answer -- 答案错误。
Presentation Error
-- 输出格式不对,可检查空格、回车等等细节。
Accepted -- 恭喜恭喜!
7 08.01.2020
8 08.01.2020
ACM in HDU
2019年9月,第一次参加省赛(邀请赛)
2019年5月,浙江省“舜宇”杯首届大学生程序设计大赛
2019年11~12月,第29届ACM亚洲区北京和上海赛区比赛
2019年5月,浙江省第二届“舜宇”杯大学生程序设计大 赛
少参加4~5个赛区的比赛) 另外,每学期至少有三次月赛以及适当
的练习赛
10 08.01.2020
如何比赛? 3人组队
可以携带诸如书、手册、 程序清单等参考资料; 不能携带任何可用计算机处理的软件或数据、不 能携带任何类型的通讯工具;
可能收到的反馈信息包括:
Compile Error -- 程序不能通过编译。
现在,ACM / ICPC已成为世界各国大学生中最 具影响力的国际计算机赛事。(非官方)
ACM题目特点:
由于ACM竞赛题目的输入数据和输出数 据一般有多组(不定),并且格式多种 多样,所以,如何处理题目的输入输出 是对大家的一项最基本的要求。这也是 困扰初学者的一大问题。
下面,分类介绍:
21 08.01.2020
先看一个超级简单的题目:
/showproblem.php?pid=108 9
Run Time Error -- 程序运行过程中出现非正常中断。
Time Limit Exceeded
-- 运行超过时限还没有得到输出结果。
Wrong Answer -- 答案错误。
Presentation Error
-- 输出格式不对,可检查空格、回车等等细节。
Accepted -- 恭喜恭喜!
7 08.01.2020
8 08.01.2020
ACM in HDU
2019年9月,第一次参加省赛(邀请赛)
2019年5月,浙江省“舜宇”杯首届大学生程序设计大赛
2019年11~12月,第29届ACM亚洲区北京和上海赛区比赛
2019年5月,浙江省第二届“舜宇”杯大学生程序设计大 赛
少参加4~5个赛区的比赛) 另外,每学期至少有三次月赛以及适当
的练习赛
10 08.01.2020
如何比赛? 3人组队
可以携带诸如书、手册、 程序清单等参考资料; 不能携带任何可用计算机处理的软件或数据、不 能携带任何类型的通讯工具;
可能收到的反馈信息包括:
Compile Error -- 程序不能通过编译。
现在,ACM / ICPC已成为世界各国大学生中最 具影响力的国际计算机赛事。(非官方)
ACM入门之三-位运算ppt课件
上面程序的输出结果是:
n1=78000,n2=-32768,n3=32768,c=c0,c<<4=3072
右移运算符
右移运算符“>>”是双目运算符。
其计算结果是把“>> ”的左操作数的各二进位全部 右移若干位后得到的值,要移动的位数就是“>>”的 右操作数。移出最右边的位就被丢弃。
对于有符号数,如long,int,short,char类型变量, 在右移时,符号位(即最高位)将一起移动, 并且大多数C/C++编译器规定,如果原符号位 为1,则右移时右边高位就补充1,原符号位为0, 则右移时高位就补充0。
右移运算符实例
#include <stdio.h> main() { int n1 = 15; short n2 = -15; unsigned short n3 = 0xffe0; unsigned char c = 15; n1 = n1>>2; n2 >>= 3; n3 >>= 4; c >>= 3; printf(
例如:表达式“21 | 18 ”的值是23(即二进制数 10111)。 按位或运算通常用来将某变量中的某些位置1或 保留某些位不变。 例如,如果需要将int型变量n的低8位全置成1, 而其余位不变,则可以执行:
n |= 0xff;
13
按位异或
按位异或运算符“^”是双目运算符。
功能:将参与运算的两操作数各对应的二进制位进 行异或操作,即只有对应的两个二进位不相同时, 结果的对应二进制位才是1,否则为0。
HDU3782xxx定律
/showproblem.php?pid=3782 Problem Description
杭电acm初学者通用课件
该竞赛旨在通过解决一系列复杂的编程问题,来考察参赛者 的算法设计、数据结构选择、编程技巧等方面的能力,以及 团队协作和解决问题的能力。
ACM/ICPC的意义
1 2 3
提高编程能力和算法设计能力
ACM/ICPC的题目通常涉及各种算法和数据结构 ,通过解决这些题目,可以提高编程能力和算法 设计能力。
培养团队协作和沟通能力
入/删除操作。
树形数据结构
包括二叉树、多叉树、B树 等。这些数据结构用于表 示层次关系和进行高效的
查找操作。
图数据结构
由节点和边组成的数据结 构,用于表示对象之间的 关系。常见的图数据结构 有邻接矩阵和邻接表等。
03
刷题技巧
如何选题
难度适中
选择难度适中的题目,逐步提升解题能力 。
覆盖面广
尽量选择涉及多种知识点的题目,提高知 识掌握的全面性。
对算法的原理和实现细节理解不足,导致 在解题过程中出现错误。
代码实现错误
由于编程语言和技巧不熟练,导致代码实 现出现错误。
忽视题目要求
在解题过程中忽视题目的特殊要求,导致 答案不符合题目要求。
高分选手的共性
01 良好的数学基础
高分选手通常具备扎实的数学 基础,能够快速理解和运用数 学原理。
02 高效的算法思维
详细描述
参与开源项目可以了解实 际项目中的算法和数据结 构应用,组织线上讨论可 以与其他人交流学习经验 ,拓宽视野和思路。
总结词
积极参与开源社区和线上 讨论。
详细描述
通过参与开源社区和线上 讨论,可以了解最新的技 术动态和趋势,同时也可 以结交志同道合的朋友, 共同进步。
06
结束语
不断实践和学习
高分选手在解题时能够迅速找 到合适的算法,并高效实现。
ACM/ICPC的意义
1 2 3
提高编程能力和算法设计能力
ACM/ICPC的题目通常涉及各种算法和数据结构 ,通过解决这些题目,可以提高编程能力和算法 设计能力。
培养团队协作和沟通能力
入/删除操作。
树形数据结构
包括二叉树、多叉树、B树 等。这些数据结构用于表 示层次关系和进行高效的
查找操作。
图数据结构
由节点和边组成的数据结 构,用于表示对象之间的 关系。常见的图数据结构 有邻接矩阵和邻接表等。
03
刷题技巧
如何选题
难度适中
选择难度适中的题目,逐步提升解题能力 。
覆盖面广
尽量选择涉及多种知识点的题目,提高知 识掌握的全面性。
对算法的原理和实现细节理解不足,导致 在解题过程中出现错误。
代码实现错误
由于编程语言和技巧不熟练,导致代码实 现出现错误。
忽视题目要求
在解题过程中忽视题目的特殊要求,导致 答案不符合题目要求。
高分选手的共性
01 良好的数学基础
高分选手通常具备扎实的数学 基础,能够快速理解和运用数 学原理。
02 高效的算法思维
详细描述
参与开源项目可以了解实 际项目中的算法和数据结 构应用,组织线上讨论可 以与其他人交流学习经验 ,拓宽视野和思路。
总结词
积极参与开源社区和线上 讨论。
详细描述
通过参与开源社区和线上 讨论,可以了解最新的技 术动态和趋势,同时也可 以结交志同道合的朋友, 共同进步。
06
结束语
不断实践和学习
高分选手在解题时能够迅速找 到合适的算法,并高效实现。
ACM课件(lecture03)递推求解-PPT文档资料43页
17.01.2020
21
思考题:平面分割方法
问题的提出: 设有n条封闭曲线画在平面上,而任
何两条封闭曲线恰好相交于两点,且任何 三条封闭曲线不相交于同一点,问这些封 闭曲线把平面分割成的区域个数。
17.01.2020
22
简单分析——
2 1
14 23
n=1 n=2
8 1
5
3
2
4
6
7
n=3
14
6
10 11 3 12 2
“佐罗”的烦恼
说起佐罗,大家首先想到的除了他脸上的面具 ,恐怕还有他每次刻下的“Z”字。我们知道, 一个“Z”可以把平面分为2部分,两个“Z”可 以把平面分为12部分,那么,现在的问题是: 如果平面上有n个“Z”,平面最多可以分割为几 部分呢? 说明1:“Z”的两端应看成射线 说明2:“Z”的两条射线规定为平行的
f(n)=f(n-1)+f(n-2)+f(n-3); 其中f(1)=1,f(2)=2,f(3)=4
17.01.2020
29
最后一个思考题(有点难度)
17.01.2020
30
分析过程(1)
设:F(n)表示n个人的合法队列,则:
按照最后一个人的性别分析,他要么是男, 要么是女,所以可以分两大类讨论:
17.01.2020
13
是不是这个——
F(1)=2; F(n) = F(n-1)+n;
化简后: F(n) = n(n+1)/2 +1;
17.01.2020
14
太简单了?
来个稍微麻烦一些的
17.01.2020
15
例:(2050)折线分割平面
ACM培训精品PPT课件
自己过滤空格?麻烦!
输入输出
读一个非空白字符, 方法一:
char str[2]; scanf(“%1s”, str); // %1s扫描前导空白,并且只读一个字符 char c = str[0]; 方法二: 强制扫描空白 在%前面加上一个空格表示“强制扫描前导空白” scanf(“ %c”, &ch); 前面那个读人物信息的完整scanf语句:
LCS (Longest Common Subsequence) 最长 公共子串
输入输出
C:
scanf printf
C++:
cin cout
速度快 格式容易控制
使用简单, 自动识别类型 格式控制较麻烦
数据规模较大时, 推荐(必须)使用scanf 以 避免超时(TLE)
输入输出
cout: 带缓冲输出 printf: 不带缓冲输出
Ctrl+Z 2.最好不要把C和C++的输入输出语句混着用,会造成一些莫名其妙的问题 3.我个人倾向于使用纯C的输入输出,因为方便且速度快。
关于重定向操作
当程序要输入的内容很多时,从文件读入的操作变得非常重 要,特别是需要调试时,这样可以避免你反复的从键盘敲入重
复的内容。
使用标准输入语句,可以使用重定向命令行
scanf(“%s %c %s”, name, &gender, ability);
输入输出
同理,我们也可以用其它字符来扫描其它类型 的无关输入
比如,输入年月日的信息
2007-08-03 scanf(“%d-%d-%d”, &y, &m, &d); 其它类似
浮点数的输入问题
为什么说while(in!=0.00)不合理呢? 如果不合理应该怎么判断!!
ACM 入门精品PPT课件
2020/10/21
10
如何排名?
首先根据解题数目进行排名。 如果多支队伍解题数量相同,则根据总用时加上惩
罚时间进行排名。 总用时和惩罚时间由每道解答正确的试题的用时加
上惩罚时间而成。 每道试题用时将从竞赛开始到试题解答被判定为正
确为止,其间每一次错误的运行将被加罚20分钟时 间,未正确解答的试题不记时。
州);
2020/10/21
7
ACM in XTU
2004年,第一次参加亚洲区预选赛(网络预赛) 2005~2011,每年10月左右——
湖南省第1~6届大学生程序设计竞赛 2004~2010,每年10~12月——
第29~35届ACM国际大学生程序设计竞赛 亚洲区预选赛
2020/10/21
8
预期赛事(今后每年)
校程序设计竞赛
个人编程能力的比拼 中文或者英文题目,考察编程基本功
2020/10/21
13
ACM队队员的基本原则
基本要求
人品好 愿意花时间在这项赛事上 有团队合作精神
能力要求
程序设计 英语科技文献阅读
数学
2020/10/21
14
开课目的
为湘大ACM代表队培养后备人才 提高分析问题和应用计算机编程解决
ACM
第一讲
ACM入门
(Introduction to ACM)
2020/10/21
2
第一部分
ACM简介
2020/10/21
What is ACM ?
ACM-(Association for Computing Machinery)
成立于计算机诞生次年,是目前计算 机学界中历史最悠久、最具权威性的 组织…
杭电ACM注册讲解
杭电acm注册
• 几点说明: • 1、登录名需未被别人注册过 • 2、登录名注册后丌可改 昵称可改
• 填写完成后 按右下角 Submit 提交
杭电acm注册
• 错误示例:
杭电acm注册
• 结果是:
杭电acm注册
• 错误原因
1、验证码错误 2、注册名不合法 3、两次密码输入不同
杭电acm注册
杭电acm注册
附: 基础题:1000、1001、1004、1005、1008、1012、1013、1014、1017、 1019、1021、1028、1029、1032、1037、1040、1048、1056、 1058、1061、1070、1076、1089、1090、1091、1092、1093、 1094、1095、1096、1097、1098、1106、1108、1157、1163、 1164、1170、1194、1196、1197、1201、1202、1205、1219、 1234、1235、1236、1248、1266、1279、1282、1283、1302、 1303、1323、1326、1330、1334、1335、1339、1390、1391、 1393、1395、1397、1405、1406、1407、1408、1412、1418、 1420、1465、1491、1555、1562、1563、1570、1587、1673、 1678、1708、1718、1720、1785、1799、1859、1862、1877、 1898、1976、1977、1985、1994、2000、2001、2002、2003、 2004、2005、2006、2007、2008、2009、2010、2011、2012、 2013、2014、2015、2016、2017、2018、2019、2020、2021、 2022、2023、2024、2025、2026、2027、2028、2029、2030、 2031、2032、2033、2034、2035、2039、2040、2042、2043、 2048、2049、2051、2053、2055、2056、2057、2060、2061、 2071、2073、2075、2076、2078、2081、2083、2088、2090、 2092、2093、2095、2096、2097、2098、2099、2101、2103、 2106、2107、2109、2113、2114、2115、2123、2131、2132、 2133、2135、2136、2137、2138、2139、2143、2148、2153、 2156、2161、2162、2164、2178、2186、2192、2200、2201、 2212、2304、2309、2317、2401、2500、2502、2503、2504、 2519、2520、2521、2523、2524、2535、2537、2539、2547、 2548、2549、2550、2551、2552、2555、2560、2561、2562、 2566、2567、2568、2700、2710、
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
HDU-ACM * 集训队*
17 2019/3/23
放松完毕 回到正题
18 2019/3/23
开课目的
– 为杭电ACM代表队培养后备人才 – 提高分析问题和应用计算机编程解 决问题的能力 – 培养必要的自学能力 – 培养学生的协调和沟通能力 – 体会学习的快乐
19 2019/3/23
如何入门呢?
7 2019/3/23
8 2019/3/23
ACM in HDU
2003年9月,第一次参加省赛(邀请赛)
2004年5月,浙江省“舜宇”杯首届大学生程序设计大赛 2004年11~12月,第29届ACM亚洲区北京和上海赛区比赛
2005年5月,浙江省第二届“舜宇”杯大学生程序设计大 赛
2005年11月,参加中国大陆的三站亚洲区比赛
校程序设计竞赛
– 个人编程能力的比拼 – 中文或者英文题目,考察编程基本功
14 2019/3/23
ACM队队员的基本原则
基本要求
– 人品好 – 愿意花时间在这项赛事上 – 有团队合作精神
能力要求
– 程序设计 – 英语科技文献阅读
– 数学
15 2019/3/23
杭电参赛历程
16 2019/3/23
12 2019/3/23
比赛形式
– 1支队伍1台机器(提供打印服务) – 上机编程解决问题(可带纸质资料) – 实时测试,动态排名
试题
– 6-10题 – 全英文(可以带字典)
时间:持续5个小时
13 2019/3/23
ACM .vs. 校程序设计竞赛
ACM竞赛
– 团队合作精神 – 即时提交,通过所有数据才能得分 – 全英文题目,题目考察范围广
20 2019/3/23
ACM题目特点:
由于ACM竞赛题目的输入数据和输出数 据一般有多组(不定),并且格式多种 多样,所以,如何处理题目的输入输出 是对大家的一项最基本的要求。这也是 困扰初学者的一大问题。 下面,分类介绍:
21 2019/3/23
先看一个超级简单的题目:
/showproblem.php? pid=1089
ACM 程序设计
计算机学院 刘春英
1 2019/3/23
第一讲
ACM入门
2 2019/3/23
第一部分
初识ACM
3 2019/3/23
What is ACM ?
ACM (Association for Computing Machinery ) 成立于计算机诞生次年,是目前计算机 学界中历史最悠久、最具权威性的组织…
Sample input: 1 5 10 20
Sample output: 6 30
22 2019/3/23
初学者很常见的一种写法:
#include<stdio.h>
void
{
main()
int a,b; scanf(“%d %d”,&a,&b); Printf(“%d”,a+b);
6 2019/3/23
ACM/ICPC in China
中国大陆高校从1996年开始参加ACM国际 大学生程序设计竞赛亚洲预赛。 前六届中国赛区设在上海,由上海大学 承办; 2002年由清华大学和西安交通大学承办; 2003年由清华大学和中山大学承办。 2004年由北京大学和上海交通大学承办。 2005年由四川大学、北大和浙大承办。 2006年由上海大学、清华和西电承办。 2007年:北航、南航、吉大、西华
Accepted -- 恭喜恭喜!
11 2019/3/23
如何排名?
首先根据解题数目进行排名。 如果多支队伍解题数量相同,则根据总用时加 上惩罚时间进行排名。 总用时和惩罚时间由每道解答正确的试题的用 时加上惩罚时间而成。 每道试题用时将从竞赛开始到试题解答被判定 为正确为止,其间每一次错误的运行将被加罚 20分钟时间,未正确解答的试题不记时。
}
23 2019/3/23
有什么问题呢?
这就是下面需要解决的问题
24 2019/3/23
第二部分
基本输入输出
25 2019/3/23
输入_第一类:
输入不说明有多少个Input Block,以EOF 为结束标志。 参见:HDOJ_1089 /showproblem.php?p id=1089
10 2019/3/23
如何比赛?
3人组队
可以携带诸如书、手册、 程序清单等参考资料; 不能携带任何可用计算机处理的软件或数据、不 能携带任何类型的通讯工具;
可能收到的反馈信息包括: Compile Error -- 程序不能通过编译。 Run Time Error -- 程序运行过程中出现非正常中断。 Time Limit Exceeded -- 运行超过时限还没有得到输出结果。 Wrong Answer -- 答案错误。 Presentation Error -- 输出格式不对,可检查空格、回车等等细节。
2006年5月,浙江省第二届“舜宇”杯大学生程序设计大 赛
2006年11~12月,第31届ACM首尔、北京、上海和西安赛 区比赛 今年…
9 2019/3/23
预期赛事(今后每年) 3~4月,举行校内大赛(暨选拔赛) 5月,参加浙江省大学生程序设计大赛 11月,参加ACM/ICPC亚洲区比赛(至 少参加4~5个赛区的比赛) 另外,每学期至少有三次月赛以及适当 的练习赛
4 2019/3/23
我们说的“ACM” 是什么?
5 2019/3/23
ACM/ICPC:
ACM主办的国际大学生程序设计竞赛 (International Collegiate Programming Contest),简称 ACM / ICPC,自从1977年开始至今已经连续举 办31届。其宗旨是提供一个让大学生向IT界展 示自己分析问题和解决问题的能力的绝好机会, 让下一代IT天才可以接触到其今后工作中将要 用到的各种软件。 现在,ACM / ICPC已成为世界各国大学生中最 具影响力的国际计算机赛事。(非官方)
26 2019/3/23
Hdoj_1089源代码:
#include <stdio.h> int main() {