// 此博文为迁移而来,写于2015年7月22日,不代表本人现在的观点与看法。原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w72i.html

1、总结
       向总表示今天的题目简单些,恩我觉得我又单纯了。今天的分数略低啊,第三题的动规只有10分,第一题的暴力也TLE了一堆,最后就剩下个150分了。
 
2、题解
       T1 坐船问题(TAG:结论题)

 
       简直就是一道结论题啊!这道题不存在什么算法。最开始想到的是二分图匹配,但是过于繁琐,而且已经证出存在反例。首先对于两个对象A和B,如果他们姓相同或者名相同,则将两者之间连一条边,任何相对之间存在姓相同或名相同关系的点,便会组成一个连通块,通过对其中的分析,可以得出其中的结论。具体的我没有做出来,大家可以看看解题报告中的一段话,代码就不上了。

 
T2 多边形划分问题(TAG:动态规划)
 

【P.S 标题有误,特此提醒】

一道动态规划题目,核心在于对于多边形的每一个顶点进行编号,根据n边形由n-2个三角形组成的原理,可以设计出状态。

 
代码:
---------------------------------------------------------------------------------------------------
#include cstdio
#include cstring
#define MAXN 105
#define MOD 100000
#define INF 1<<30
 
typedef long long arr[MAXN];
 
long long max(long long a,long long b) { return (a>b)?a:b; }
arr f[MAXN][MAXN],a,s1,s2,s3;
long long n;
 
void mark(arr &c)
{
        for (int i=1;i<=c[0];i++)
        {
                c[i+1]+=c[i]/MOD;
                c[i]%=MOD;
        }
        while (c[c[0]+1])
        {
                c[0]++;
                c[c[0]+1]+=c[c[0]]/MOD;
                c[c[0]]%=MOD;
        }
}
 
void multi(long long a1,long long a2,long long a3,arr &s)
{
         memset(s,0,sizeof(s));
         s[0]=s[1]=1;
         for (int i=1;i<=s[0];i++) s[i]*=a1; mark(s);
         for (int i=1;i<=s[0];i++) s[i]*=a2; mark(s);
         for (int i=1;i<=s[0];i++) s[i]*=a3; mark(s);
}
 
void addVal(arr a,arr b,arr &c)
{
     memset(c,0,sizeof(c));
     c[0]=max(a[0],b[0]);
     for (int i=1;i<=c[0];i++) c[i]=a[i]+b[i];
     mark(c);
}
 
int check(arr a,arr b)
{
        if (a[0]<b[0]) return 0;
        if (a[0]>b[0]) return 1;
        for (int i=a[0];i>=1;i--)
                if (a[i]
                else if (a[i]>b[i]) return 1;
        return 0; 
}
 
int main()
{
        freopen("polygon.in","r",stdin);
        freopen("polygon.out","w",stdout);
        scanf("%I64d",&n);
        for (int i=1;i<=n;i++) scanf("%I64d",&a[i]);
        for (int i=1;i<=n;i++)
                for (int j=1;j<=n;j++) f[i][j][0]=1;
        for (int i=n-2;i>=1;i--)
                for (int j=i+2;j<=n;j++)
                {
                        f[i][j][0]=INF;
                        for (int k=i+1;k<=j-1;k++)
                        {
                                multi(a[i],a[k],a[j],s1);
                                addVal(f[i][k],f[k][j],s2);
                                addVal(s1,s2,s3);
                                if (check(f[i][j],s3)) memcpy(f[i][j],s3,sizeof(f[i][j]));
                        }
                }
        printf("%I64d",f[1][n][f[1][n][0]]);
        for (int i=f[1][n][0]-1;i>=1;i--) printf("I64d",f[1][n][i]);
        printf("\n");
}
----------------------------------------------------------------------------------------------------
       
T3  系统可靠性问题(TAG:动态规划)
 

这道题是比较简单的完全背包问题了,但是由于考试时候匆匆忙忙,写萎了,结果只得了10分。含有一个值得注意的地方,读入的时候,对于每一个零件,题目中并没有给出他的备用零件个数选择有多少种方式,所以需要在读入时判断回车符。

 
代码略。
 
T4 重复子串问题(TAG:KMP算法)
 

暴力大法好!有人打了个暴力就A了真是不能忍。。。我开始想过这种做法,但是看到数据范围后就弃疗了,然而并不清楚为什么可以A了。先说说暴力的做法吧:对于每一个字母数字组合,记录其曾经出现过的位置,依次进行比较,得到重复串后判断是否相连即可。正解的话是江哥跟我们讲的,可以巧妙利用KMP算法的fail指针。

 
代码略。
 
 

[题解+总结]NOIP2015模拟题2的更多相关文章

  1. [考试]NOIP2015模拟题2

    // 此博文为迁移而来,写于2015年7月22日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w72i.html 1.总 ...

  2. 【题解】[NOIP模拟题]我要的幸福-C++

    题目Description我要的幸福(happiness)幸福/我要的幸福/渐渐清楚/梦想/理想/幻想/狂想/妄想/我只想坚持每一步/该走的方向/就算一路上/偶尔会沮丧/生活是自己/选择的衣裳/幸福/ ...

  3. csu 1312 榜单(模拟题)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1312 1312: 榜单 Time Limit: 1 Sec  Memory Limit: 128 ...

  4. 【NOIP2015模拟11.4】JZOJ8月6日提高组T1 刷题计划

    [NOIP2015模拟11.4]JZOJ8月6日提高组T1 刷题计划 题目 题解 题意 有\(n\)道题,编号为1~\(n\) 给出\(m\)次操作 每次操作有3种类型 1 \(x\) 表示交了\(A ...

  5. 《ACM国际大学生程序设计竞赛题解Ⅰ》——模拟题

    这篇文章来介绍一些模拟题,即一类按照题目要求将现实的操作转换成程序语言. zoj1003: On every June 1st, the Children's Day, there will be a ...

  6. PAT甲级 模拟题_C++题解

    模拟题 PAT (Advanced Level) Practice 模拟题 目录 1008 Elevator (20) 1042 Shuffling Machine (20) 1046 Shortes ...

  7. 【题解】NOIP2015提高组 复赛

    [题解]NOIP2015提高组 复赛 传送门: 神奇的幻方 \([P2615]\) 信息传递 \([P2661]\) 斗地主 \([P2668]\) 跳石头 \([P2678]\) 子串 \([P26 ...

  8. JZOJ 4298. 【NOIP2015模拟11.2晚】我的天

    4298. [NOIP2015模拟11.2晚]我的天 (File IO): input:ohmygod.in output:ohmygod.out Time Limits: 1000 ms Memor ...

  9. 【NOIP2015模拟11.5】JZOJ8月5日提高组T2 Lucas的数列

    [NOIP2015模拟11.5]JZOJ8月5日提高组T2 Lucas的数列 题目 PS:\(n*n*T*T<=10^{18}\)而不是\(10^1*8\) 题解 题意: 给出\(n\)个元素的 ...

随机推荐

  1. WPF样式

    <Window x:Class="WpfApplication1.Window1" xmlns="http://schemas.microsoft.com/winf ...

  2. ****CodeIgniter使用cli模式运行,把php作为shell编程

    shell简介 在计算机科学中,Shell俗称壳(用来区别于核).而我们常说的shell简单理解就是一个命令行界面,它使得用户能与操作系统的内核进行交互操作. 常见的shell环境有:MS-DOS.B ...

  3. 【转】JQuery插件ajaxFileUpload 异步上传文件(PHP版)

    前几天想在手机端做个异步上传图片的功能,平时用的比较多的JQuery图片上传插件是Uploadify这个插件,效果很不错,但是由于手机不支持flash,所以不得不再找一个文件上传插件来用了.后来发现a ...

  4. [LeetCode] Merge Sorted Array

    Given two sorted integer arrays A and B, merge B into A as one sorted array. Note:You may assume tha ...

  5. Freemarker使用入门

    一.概述: FreeMarker是一个模板引擎,一个基于模板生成文本输出的通用工具,使用纯Java编写 Template + data_model = output FreeMarker也是与Web容 ...

  6. jq获取鼠标位置

    jq获取鼠标位置 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  7. WPF QuickStart系列之样式和模板(Style and Template)

    在WPF桌面程序中,当我们想构建一个统一的UI表现时(在不同操作系统下,显示效果一致),此时我们就需要使用到WPF中的样式和模板技术.简单来说,如果我们需要简单的给一个Button设置宽,高,Marg ...

  8. MicroService/web Service/webAPI/RPC

    [TOC] 微服务 服务拆分,利用轻量化机制(通常为HTTP源API)实现通信,复杂度可控,独立部署,技术选型灵活,容错,扩展. 康威定律的实际体现 微服务架构模式深刻影响了应用和数据库之间的关系,不 ...

  9. 函数式编程语言LISP,python,haskell,clojure

    说说我自己的背景吧,我是个半吊子的程序员,做任何事情喜欢比较了解然后再尝试,我接触过很多语言,大多数都把它当成工具来使用 我现在的工作大部分主要在于数据挖掘与机器学习方面,也学习web开发,我第一个拿 ...

  10. jvm运行机制与内存管理

    http://blog.csdn.net/lengyuhong/article/details/5953544 http://www.cnblogs.com/nexiyi/p/java_memory_ ...