08day1
高中运动会
最大公约数
【问题描述】
梦幻城市每年为全市高中生兴办一次运动会。为促使各校同学之间的交流,采用特别的分队方式:每一个学校的同学,必须被均匀分散到各队,使得每一队中该校的人数皆相同。为增加比赛的竞争性,希望分成越多队越好。你的任务是由各校的人数决定最多可以分成的队数。
【输入】
第一行一个正整数 n ,代表学校的个数。
接下来 n 行,每行一个正整数,分别代表这 n 个学校的人数。
【输出】
最多可分成的队数。
【数据规模】
对于 100%的数据,n≤500,每个学校人数最多 10000。
【解题过程】
直接求所有数的 GCD。
智力游戏
枚举
【问题描述】
小华最近迷上了一个你小时候已经玩厌了的游戏:移火柴棒。他现在吵着要你陪她玩,你没办法,
只好写一个程序来完成这个工作了。
你被给出了一个火柴拼成的等式,比如下面这个,5+7=7:

它显然是不成立的,但是我们可以通过移动一个其中的火柴使得它成立。变成如下一个等式:

现在给出一个类似的等式,请问,最少移动多少根火柴可以使得它变成一个成立的等式?
每个数字的表示方法如下:我们用 7 根火柴表示每一个数字。火柴编号 0~6,如下图:

每一个数字都可以用对应的火柴组成的集合表示:
1:{2,5} or {1,4} 2:{0,2,3,4,6}
3:{0,2,3,5,6} 4:{1,2,3,5}
5:{0,1,3,5,6} 6:{0,1,3,4,5,6}
7:{0,2,5} 8:{0,1,2,3,4,5,6}
9:{0,1,2,3,5,6} 0:{0,1,2,4,5,6}
【输入】
输入有三个数字,分别表示上面的表达式中的从左到右的三个数字,每个数都在 0~999 之间。
【输出】
输出只需一个数,表示使等式成立最少需要移动的火柴数,不允许改变位数以及符号,不要制造 0
开头的数。
【输入样例】
5 7 7
【输出样例】
1
【解题过程】
一看数据范围二话不说就枚举了。
枚举出两个加数就能算出正确的和,然后拆解,打个表记录每个数字所需的火柴数,如果这里枚举出的两个加数以及和的总火柴数与题目给出的不相等就直接跳过。
然后计算至少需要移几根火柴才能从初始状态移到当前状态。打个表记录一个数字与另外一个数字在同一位置上的火柴数,比如 6 和 3 有四根火柴是在相同的位置上的。用总火柴数减去各个数对应的在各自位子上的火柴数之和即是最小移动步数。题目给出了不允许改变位数和符号的限制大大降低了难度。
但是中间细节错了后来查了好久才找到错。
第一次提交 70 分左右?反正没 AC。
周年纪念日
树型动规
【问题描述】
某中学校长打算举行建校 100 周年的晚会。学校的职员是分等级的,也就是说职员之间的上下级关系组成一棵以校长为树根的树。校长要亲自邀请一些职员参见晚会。同时校长亲自到场欢庆这个节日。职员用 1~n 之间的整数编号,人事处给出了每个职员的搞笑指数。如果一个人和他上司一起参加,那么便可能产生麻烦。为了使晚会的每个参加者都高兴,校长不会同时邀请某个职员和他的顶头上司。
你的任务是给出一个客人列表,使得客人的搞笑指数之和最大。
【输入】
第一行一个整数 n(1≤n≤6000)。
以下 n 行每行是相应编号职员的搞笑指数,该数的返回是[-128..127]。
然后是职员的关系树,每行格式是<x> <y>,意思是第 y 个职员是第 x 个职员的顶头上司。输入以 0 0 结束。
【输出】
最大的搞笑指数之和。
【输入样例】
7
1
1
1
1
1
1
1
1 3
2 3
6 4
7 4
4 5
3 5
0 0
【输出样例】
5
【解题过程】
很典型的树型动规,用 f(i, 0) 表示 i 没有出席所能达到的最大和,f(i, 1) 表示 i 出席了所能达到的最大和,则
f(i, 1) = sum{ f(j, 0), i 是 j 的直接上司 }
f(i, 0) = sum{ f(i, 0)+f(i, 1), i 是 j 的直接上司 }
很纠结的地方是校长到底有没有在这棵树中。不过这不是重点,NOIP 的题目不会这么坑。
08day1的更多相关文章
- 二模08day1解题报告
T1.高中运动会(match) N个数的最大公约数. gcd不解释. T2.智力游戏 火柴棒等式形如a+b=c,现在给出啊a,b,c求使等式成立的最小的移动次数. 火柴棒表示数字不用解释了吧,在此提醒 ...
随机推荐
- java 如何从配置文件(.properties)中读取内容
1.如何创建.properties文件 很简单,建立一个txt文件,并把后缀改成.properties即可 2.将.properties文件拷入src的根目录下 3..properties文件内容格式 ...
- 无限互联IOS电影项目视频笔记
下面是该iOS项目视频教程的内容大纲: 观看指南 (1)项目为第一阶段内容 (2)需要熟练掌握OC语言 (3)UI部分需要学习到第十节课 (4)项目适合刚入门的iOS开发者 1.第一天 (1)iOS ...
- 2014 ACM/ICPC Asia Regional Xi'an Online(HDU 5007 ~ HDU 5017)
题目链接 A题:(字符串查找,水题) 题意 :输入字符串,如果字符串中包含“ Apple”, “iPhone”, “iPod”, “iPad” 就输出 “MAI MAI MAI!”,如果出现 “Son ...
- POJ 3335 Rotating Scoreboard(半平面交求多边形核)
题目链接 题意 : 给你一个多边形,问你在多边形内部是否存在这样的点,使得这个点能够看到任何在多边形边界上的点. 思路 : 半平面交求多边形内核. 半平面交资料 关于求多边形内核的算法 什么是多边形的 ...
- WebSocket 是什么原理?为什么可以实现持久连接
你可以把 WebSocket 看成是 HTTP 协议为了支持长连接所打的一个大补丁,它和 HTTP 有一些共性,是为了解决 HTTP 本身无法解决的某些问题而做出的一个改良设计.在以前 HTTP 协议 ...
- spring_150806_hibernate_non_transaction
添加hibernate的相关jar包! 实体类: package com.spring.model; import javax.persistence.Entity; import javax.per ...
- scp在Linux主机之间复制不用输入密码
把你的本地主机用户的ssh公匙文件复制到远程主机用户的~/.ssh/authorized_keys文件中,假设本地主机linux(10.1.1.1),远程主机linux(10.1.1.2) 一,在li ...
- Java-马士兵设计模式学习笔记-责任链模式-FilterChain功能
一.目标 增加filterchain功能 二.代码 1.Filter.java public interface Filter { public String doFilter(String str) ...
- Java-在线聊天系统-非线程
一.概述 1.目标:建立基于tcp协议的聊天系统 2.思路:用java socket编程 二.代码 1.ChatServer.java import java.io.DataInputStream; ...
- springMVC找不到JS等文件
应用springMVC时 JS等文件找不到错误 应用springMVC时如果配置URL映射时如下配置 <servlet> <servlet-name>appSe ...