题目:点此

我处理这种多组数据的方法被我叫做“mains法”,就是先假设只有一组数据,写一个代码,然后把那个main函数改成mains,最后写一个真正的main函数。

这个“真正的”main函数一般有两种 1.告诉你数据组数:

  1. int main(){
  2. int t;
  3. cin >> t;
  4. for(int i=;i<t;i++){
  5. mains();
  6. }
  7. return ;
  8. }

2.不告诉你数据组数:

  1. int main(){
  2. int *|*;//*|*表示根据实际情况会发生变化,这里*|*表示mains中第一个读入的数据,放在main函数里读入
  3. while(cin >> *|*){
  4. mains(*|*);//*|*用参数的形式告诉mains
  5. }
  6. }

好了,进入正题


这道题我的思路是:先读入数据,建立一棵类似于邻接表存储的树(这样方便调 试,而且貌似也没有坏处),然后判断n%k是否等于0,不等直接NO,return 0! 等于继续。进行深搜,首先找到下一个访问的顶点进行访问,然后判断返回值(那个结点是该分组的第几个节点) 是否大于k或=-1(=-1说明已经无法划分),返回-1,否则判断是否等于k,若等于说明已有一组,无需继续配对 否则将ans变量加上这个返回值,该节点访问完毕后return ans,ans初始值为1,不为0。 最后如果根节点返回值不为k,输出Yes,否则NO。

(为什么是不等于?我不知道,不等于就AC,等于就爆零) 代码:

  1. #include <cstdio>
  2. #include <vector>
  3. using namespace std;
  4. bool color[]={true};
  5. vector <int> tree[];
  6. int k;
  7. int dfs(int now){
  8. color[now]=false;
  9. int number=;
  10. for(int i=;i<tree[now].size();i++){
  11. if(color[tree[now][i]]){
  12. int a=dfs(tree[now][i]);
  13. if(a>k||a==-){
  14. return -;
  15. }
  16. if(a==k){
  17. continue;
  18. }
  19. number+=a;
  20. }
  21. }
  22. return number;
  23. }
  24. int mains(){
  25. int n;
  26. scanf("%d %d",&n,&k);
  27. for(int i=;i<n;i++){
  28. tree[i].clear();
  29. color[i]=true;
  30. }
  31. for(int i=;i<n-;i++){
  32. int x,y;
  33. scanf("%d %d",&x,&y);
  34. x--;
  35. y--;
  36. tree[x].push_back(y);
  37. tree[y].push_back(x);
  38. }
  39. if(n%k!=){
  40. puts("NO");
  41. return ;
  42. }
  43. if(dfs()==k){
  44. puts("YES");
  45. }
  46. else{
  47. puts("NO");
  48. }
  49. return ;
  50. }
  51. int main(){
  52. int t;
  53. scanf("%d",&t);
  54. for(int i=;i<t;i++){
  55. mains();
  56. //puts("\n");
  57. }
  58. return ;
  59. }

代码

补充:

在你已熟练printf和scanf的时候,不要用cin、cout,用printf、scanf,不然cin数据一大,光读数据就会 TLE,还有如果你会且熟练getchar()或cin.get()读入整数的话,就用它,应为有些时候数据很大,scanf也 会TLE,所以就要用到它。

附录:

用getchar或cin.get()读入数据的基本模板:

  1. int read()//视需要可变成long long,unsighed long long……
  2. {
  3. int s=,w=;//返回值类型变了,s也要变,w不用变
  4. char ch=getchar();
  5. while(ch<''||ch>'')
  6. {
  7. if(ch=='-')
  8. w=-;
  9. ch=getchar();
  10. }
  11. while(ch>=''&&ch<='')
  12. s=s*+ch-'',ch=getchar();
  13. return s*w;
  14. }

(这次调整了一下顺序,犯的错误和收获在后面)

犯的错误:

1.dfs如果不满足条件应该return不是exit,因为如果是单测试数据,这样做是可以的,可是它有多组数据,这样做会直接结束程序,导致后面的测试数据没法输出答案。

2.tree邻接表没进行初始化(clear)。

3.用vector实现的邻接表不用头节点。

4.exit改成return后输出NO的语句没去掉。

5.判断是否整除的语句应该放在读数据的后面,不然数据就没读完,后面的数据会被认为是下一组数据的开始。

6.color数组没初始化。

7.第十行是tree[now]不是tree[i]。

收获:

1.尽量不用exit,除非不是在做题(别忘了我还在开发游戏)

2.遇到多测试数据的题目,在mains里,三省代码:变量初始化了吗??数组初始化了吗??stl容器初始化了吗??

3.添加头节点的时候,问自己:需要吗??若需要,写dfs时,再问一遍:循环时是否访问了头节点??

4.该要改全面。

5.任何操作(除了输入必须操作)都要在读数据后执行。

结题报告--洛谷P3915的更多相关文章

  1. 斜率优化dp学习笔记 洛谷P3915[HNOI2008]玩具装箱toy

    本文为原创??? 作者写这篇文章的时候刚刚初一毕业…… 如有错误请各位大佬指正 从例题入手 洛谷P3915[HNOI2008]玩具装箱toy Step0:读题 Q:暴力? 如果您学习过dp 不难推出d ...

  2. 《基于Arm实验箱的国密算法应用》课程设计 结题报告

    <基于Arm实验箱的国密算法应用>课程设计 结题报告 小组成员姓名:20155206赵飞 20155220吴思其 20155234昝昕明 指导教师:娄嘉鹏 设计方案 题目要求:基于Arm实 ...

  3. 《基于Cortex-M4的ucOS-III的应用》课程设计 结题报告

    <基于Cortex-M4的ucOS-III的应用>课程设计 结题报告 小组成员姓名:20155211 解雪莹 20155217 杨笛 20155227 辜彦霖 指导教师:娄嘉鹏 一.设计方 ...

  4. 【刷题】洛谷 P3690 【模板】Link Cut Tree (动态树)

    题目背景 动态树 题目描述 给定n个点以及每个点的权值,要你处理接下来的m个操作.操作有4种.操作从0到3编号.点从1到n编号. 0:后接两个整数(x,y),代表询问从x到y的路径上的点的权值的xor ...

  5. 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...

  6. 2016noipday1t1玩具迷题结题报告

    经常读这个代码有益于比赛时想起一些思路.... day1t1,洛谷dalao称之为水题...??然后我去年还是没拿到分,就这个,我还就写了40%的数据,AC到40,然而这不是关键,注释了freopen ...

  7. 代码源 每日一题 分割 洛谷 P6033合并果子

    ​ 题目链接:切割 - 题目 - Daimayuan Online Judge 数据加强版链接: [NOIP2004 提高组] 合并果子 加强版 - 洛谷 题目描述 有一个长度为 ∑ai 的木板,需要 ...

  8. 结题报告--P5551洛谷--Chino的树学

    题目:点此 题目描述 Chino树是一棵具有某种性质的满二叉树,具体来说,对于这棵树的每一个非叶子节点,它的左子节点(A)(A)(A)的右子节点(C)(C)(C)与它的右子节点(B)(B)(B)的左子 ...

  9. 2013山东省ICPC结题报告

    A.Rescue The Princess 已知一个等边三角形的两个顶点A.B,求第三个顶点C,A.B.C成逆时针方向. 常规的解题思路就是用已知的两个点列出x,y方程,但这样求出方程的解的表达式比较 ...

随机推荐

  1. 浅谈javascript函数执行过程

    javascript函数执行过程: 1. 为函数创建一个执行环境 2. 复制函数的 [[scopes]] 属性中的对象构建起执行环境的作用链域 3. 创建函数活动对象并推入执行环境作用链域的前端 4. ...

  2. Java JDBC调用inout类型参数的存储过程

    存储过程参数类型:in.out.inout,in:输入类型,out:输出类型,inout:既可输入,也可以输出. 一.JDBC调用inout类型参数的存储过程,并且获得返回值 Class.forNam ...

  3. python中使用xlrd读excel使用xlwt写excel

    原文地址 :http://www.bugingcode.com/blog/python_xlrd_read_excel_xlwt_write_excel.html 在数据分析和运营的过程中,有非常多的 ...

  4. 吴裕雄--天生自然 PHP开发学习:PhpStorm的配置与安装

    下载安装包

  5. Nginx部署前后端分离服务

    飘过... 一,安装Nginx 二,配置nginx 一般nginx配置文件在etc目录下 另,如何找nginx.conf配置文件: 在前后端分离端项目里,前端的代码会被打包成为纯静态文件.使用 Ngi ...

  6. git 学习 3

    远程仓库 添加远程库 GitHub 注册账号并建立 repository,Clone with SSH 1 $ ssh-keygen -t rsa -C "youremail@example ...

  7. 如何安装与配置MySQL

    关键词:MySQL,安装,配置 这一节,我们讨论一下MySQL的安装配置与卸载 下载 网址:https://dev.mysql.com/downloads/mysql/ 选择社区版,找到对应的电脑,开 ...

  8. Ubunt 16.04 安装 Beyond compare 4

    1. 下载安装包: 2. 安装步骤 3. 运行并注册 之前Beyond compare 3 只有32位,在Ubunt 16.04上运行效率非常低,所以只有安装最新的Beyond compare 4,安 ...

  9. 在Linux上显示正在运行的进程的线程ID

    在Linux上显示正在运行的进程的线程ID 在上Linux," ps -T"可以显示正在运行的进程的线程信息: # ps -T 2739 PID SPID TTY STAT TIM ...

  10. python爬虫-纠正MD5错误认知

    m = md5(".encode()) print(m.hexdigest()) # 25d55ad283aa400af464c76d713c07ad m = md5(".enco ...