青少年编程知识记录 codecoming

EasyX—制作复杂动画效果

这篇文章来简单学习一下复杂动画效果。本文资源下载地址:这里参考代码#include <graphics.h> #include <conio.h> int main() { initgraph(480, 300); IMAGE img_human,img_walls; // 定义 IMAGE 对象 loadimage(&img_human, "D:
作者:亿万年的星光 分类:趣味小程序 浏览:

C++中的宏

一、预处理和编译器    首先,预编译器就是在编译器之前运行,换句话说,预编译器根据程序员的指示,决定实际要编译的内容。预编译器编译指令都以 # 开头。例如:1. #include<iostream> 2. #define ARRAY_SIZE=25 int a[ARRAY_SIZE] 3. #define SQUARE(x) ((x)*(x)) int x=SQUARE(
作者:亿万年的星光 分类:C++知识 浏览:

【题解】滑翔翼

【题目描述】

小T和小K都是OIER,入选省队后有幸去苏州参加JSOI集训,训练之余,他们相约一起去苏州乐园玩。

苏州乐园里有一个非常热门的游乐项目叫双人滑翔翼。小T想和小K一起乘双人滑翔翼,但是排在他们前面的一大群人却为了搭配问题而争执不休,小T和小K便自告奋勇上前为他(她)们排扰解难。

排在小T和小K前面的一大群人中有N个男人和N个女人。本着“男女搭配,干活不累”的原则,他(她)们希望一男一女结成对子飞上天去。由于双人滑翔翼飞行的稳定性很大程度上决定于两侧是否平衡,所以两个人体重相差越小则组成的搭档也越好。

现在已知每个人的体重,你的任务就是将所有人结成N对并使各对的体重差的总和最小。一对的体重差定义为重的减轻的的值,此值一定大于等于0,譬如有一对人,男的体重为50,女的体重为55,则他(她)们的体重差为5,反过来如果男的体重为55,女的体重为50,则他(她)们的体重差仍然是5。

【输入描述】

第一行包含一个自然数N(1≤N≤1000),表示有N对人;

第2~N+1行:每行包含一个自然数,表示N个男人的体重;

第N+2~2N+1行:每行包含一个自然数,表示N个女人的体重。

【输出描述】

仅有一行包含一个整数,表示配对后N对男女的体重差的总和的最小值。

【样例输入】

4  2  8  5  5  1  4  10  7

【样例输出】

6
作者:亿万年的星光 分类:题解目录 浏览:

C++中的溢出

一、编程中的溢出   溢出是C++语言中最常见的漏洞。最常见的溢出包括数组溢出、数溢出、缓冲区溢出、指针溢出以及栈溢出。二、数组溢出      数组溢出是最常见的一种溢出。因为在C++语言中,含N个元素的数组下标是从0开始,到N-1结束,而且C++语言没有提供数组越界检查的机制。  也就是说,一个含有n个元素的数组,其遍历元素的方式为:      
作者:亿万年的星光 分类:C++知识 浏览:

STL入门——容器3:map

一、定义    Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候,在编程上提供快速通道。这里说下map内部数据的组织,map内部自建一颗红黑树(一 种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的。map是一类关联式容器。它的特点是增加
作者:亿万年的星光 分类:C++知识 浏览:

深搜剪枝技巧

一、什么是剪枝

     首先应当明确的是,“剪枝”的含义是什么。我们知道,搜索的进程可以看作是从树根出发,遍历一棵倒置的树——搜索树的过程。而所谓剪枝,顾名思义,就是通过某种判断,避免一些不必要的遍历过程,形象的说,就是坚强搜索树中的某些“枝条”,故称剪枝。

    我们在编写搜索程序的时候,一般都要考虑剪枝。显而易见,应用剪枝优化的核心问题是设计剪枝判断方法,即确定哪些枝条应当舍弃,哪些枝条应当保留。设计好的剪枝判断方法,往往能够使程序的运行时间大大缩短;否则,可能适得其反。



二、剪枝的原则

    1.正确性:

    我们知道,剪枝方法之所以能够优化程序的执行效率,正如前文所述,是因为它能够“剪去”搜索树中的一些“枝条”。然而,如果在剪枝的时候,将“长有”我们所需要的解的枝条也剪掉了,那么,一切优化也就失去了意义。所以,对剪枝的第一个要求就是正确性,即必须保证不丢失正确的结果,这是剪枝优化的前提。

    2.准确性:

    在保证正确性的基础上 ,对剪枝判断的第二个要求就是准确性,即能够尽可能多地剪去不能通向正确的枝条。剪枝方法只有在具有了较高的准确性的时候,才能真正收到优化的效果。

    3.高效性:

    一般来说,设计好剪枝判断方法之后,我们对搜索树的每个枝条都要执行一次判断操作。然而,由于是利用出解的“必要条件”进行判断,所以,必然是有很多不含正解的枝条没有被剪枝。这些情况下的剪枝判断操作,对于程序的

效率提高无疑是具有副作用的。为了尽量减少剪枝判断的副作用,我们除了要下功夫改善判断的准确性之外,经常还需要提高判断操作本身的时间效率。

    然而这就带来了一个矛盾:我们为了加强优化效果,就必须提高剪枝判断的准确性,因此,常常不得不提高判断操作的复杂度,也就同时降低了剪枝判断的时间效率;但是,如果剪枝判断的时间消耗过多,就有可能降低、甚至完全抵消

提高判断准确性所能带来的优化效果,这恐怕会得不偿失。很多情况下,能否较好地解决这个矛盾,往往成为搜索算法优化的关键。

    综上所述:我们可以把剪枝优化的主要原则归结为六个字:正确、准确、高效。

三、深度优先搜索的优化技巧

    1.优化搜索顺序

     在一些搜索问题中,搜索树的各个层次、各个分支之间的顺序不是固定的。不同的搜索顺序会产生不同的搜索树形态,其规模大小也相差甚远。

    2.排除等效冗余

      在搜索过程中,如果我们能够判断从搜索树的当前节点上沿着某几条不同分支到达的子树是等效的,那么只需要对其中的一条分支执行搜索。

    3.可行性剪枝

        在搜索过程中,及时对当前状态进行检查,如果发现分支已经无法到达递归边界就及时回溯。这就好比我们在道路上行走时,远远看到前方是一个死胡同,就应该立即折返,走到路的尽头再返回。

某些题目条件的范围限制是一个区间,此时可行性剪枝也被称为上下界。

    4.最优性剪枝

在最优化问题的搜索过程中,如果当前花费的代价已经超过当前搜到的最优解,那么取多么优秀的策略到达递归边接,都不可能更新答案,此时可以停止对当前分支的搜索回溯。

    5.记忆化

可以记录每个状态的搜索结果,在重复遍历一个状态时直接搜索并返回。这好比我们进行深度优先遍历时,标记一个节点是否已经被访问过。



四、例题



【问题描述】

将整数n分成k份,且每份不能为空,问有多少种不同的分法?当n=7,k=3时,下面三种分法是被认为是相同的:1,1,5;

1,5,1;5,1,1。

【输入格式】

输入文件只有一行,为两个整数n和k。(6<n<=200, 2<=k<=6)

【输出格式】

输出文件仅有一行,为一个整数,即不同的分法数。

【样例输入】

7 3

【样例输出】

4

【样例解释】

四种分法为:1,1,5;1,2,4;1,3,3;2,2,3;

【数据规模】

对100%的数据,6<=n<=200, 2<=k<=6
作者:亿万年的星光 分类:C++知识 浏览:

【题解】链表操作

【题目描述】

给定一个N个数的数组,M次操作,每次操作为下列操作之一。求最后的数组。

操作1:在第X个数之后插入一个数Y。

操作2:删除第X个数。

操作3:对区间[XY]进行排序。

操作4:对区间[XY]进行翻转。

操作5:删除区间[XY]中值为Z的数。

【输入描述】

第一行两个整数N,M(N,M≤100000)含义见试题描述。

第二行N个整数,表示原来的数组。

接下来M行,每行第一个数OPT,表示操作类型。

对于操作1,接下来两个数X,Y,含义见题面描述,保证0≤X≤当前数的个数,若X=0,表示在数组开头插入。

对于操作2,接下来一个数X,含义见题面描述,保证1≤X≤当前数的个数。

对于操作3,接下来两个数X,Y,含义见题面描述,保证1≤X≤Y≤当前数的个数,保证操作3不超过10个。

对于操作4,接下来两个数X,Y,含义见题面描述,保证1≤X≤Y≤当前数的个数,保证操作4不超过10个。

对于操作5,接下来三个数X,Y,Z,含义见题面描述,保证1≤X≤Y≤当前数的个数,保证操作5不超过10个。

【输出描述】

输出若干个数,表示最后的数组。

【样例输入】

5 5  1 4 3 2 5  3 2 4  4 4 5  5 2 3 2  5 2 3 1  1 0 9



【样例输出】

9 1 3 5 4
作者:亿万年的星光 分类:题解目录 浏览:

【题解】小X与机器人

【题目描述】小X的老师很喜欢围棋。众所周知,围棋的棋盘有19行19列,共有361个交叉点。为方便起见,我们把这些行列按顺序编号为1~19,并用(x, y)表示第x列第y行的位置。例如下图中,A用(16,4)表示,B用(14, 3)表示。小X在做一个机器人的项目,他正思考这样一个问题:如果一个小机器人从(x1, y1)这个位置出发,沿直线移动到(x2, y2)这个位置,它一共经过了多少个交叉点?注意起点和终点也算作经过,因此至少经过了2个交叉点。【输入描述】输入数据仅有一行包含4个用空格隔开的正整
作者:亿万年的星光 分类:题解目录 浏览:

【题解】游览动物园

【题目描述】

动物园有很多游览区,小红已经在动物园的一个游览区游览,突然接到电话,要半个小时内到动物园外面跟一个朋友见面。半个小时小红只够游览完当前区域之后,游览一个最近的景区。已知从一个游览区域只能沿着地图(地图的长宽均小于100)中的直线走(上下左右四个方向),请问离小红当前游览区的最近的一个游览区的坐标是多少,如果有多个点离小红的位置都很近,请输出离出口最近的那个点的坐标(不存在多个点距离出口一样近)?

例如:假设小红在孔雀区(3,2),离小红最近的2处游览区分别是猴山(2,0)和虎山(5,3),但猴山离入口更近,因此输出猴山的坐标。

【输入描述】

第一行2个变量,为小红所在的游览区的坐标

第二行一个整数n,为该动物园内游览区的数量(n<=100)

接下来的n行,每行2个数,代表动物园的n个游览区的坐标(本题所有的坐标值都在1~1000的范围内)

【输出描述】

离小红最近的游览区的坐标。

【样例输入】

3 2  5  2 0   5 3  3 2  5 5  3 8

【样例输出】

2 0
作者:亿万年的星光 分类:题解目录 浏览:

如何计算一个程序的运行时间(防止超时)

再一些OJ系统中,做题的时候常常会超时,但是很多人不知道自己的程序是否会超时,不知道如何检查自己的程序。这篇文章主要介绍几种监测自己程序运行时间的程序。头文件<time.h>   2.用法1:#include<stdio.h> #include<stdlib.h> #include<time.h> int main() { int n,s=0; for ( int&
作者:亿万年的星光 分类:C++知识 浏览: