【题解】游览动物园
【题目描述】
动物园有很多游览区,小红已经在动物园的一个游览区游览,突然接到电话,要半个小时内到动物园外面跟一个朋友见面。半个小时小红只够游览完当前区域之后,游览一个最近的景区。已知从一个游览区域只能沿着地图(地图的长宽均小于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
如何计算一个程序的运行时间(防止超时)
C++中双冒号(::)的用法
STL入门——容器2:set
STL入门——容器1:vector (不定长度数组)
STL入门——简单介绍
【算法】单链表的一些操作(存取、查找、取出、插入、删除)
【题解】小x与队列
【题目描述】
小X正和同学们做列队的练习。
有n名同学排成一路纵队,编号为i的同学排在从前往后数第i个位置上,即:初始时的队列为1, 2, 3, ..., n。
接下来小X会发出若干条指令,每条指令形如“请编号为x的同学排到最前面来”。(例如:若当前时刻的队列为5, 4, 3, 2, 1,发出一条x=2的指令后,队列变成了2, 5, 4, 3, 1。)
小X发出了很多很多指令,同学们晕头转向不知道该怎么排列。于是就请你算一算,执行完这些指令后,队列应该变成什么样?
【输入描述】
第一行两个用空格隔开的正整数n和m,分别表示人数和指令数。
第二行m个用空格隔开的正整数x[i],按顺序表示每次指令的x值。
【输出描述】
输出仅有一行包含n个正整数,相邻两个数之间用一个空格隔开,表示执行完所有指令后的队列。
【样例输入】
4 3 2 3 2
【样例输出】
2 3 1 4
【提示】
样例解释
第一条指令前:1 2 3 4
第一条指令后(x=2):2 1 3 4
第二条指令后(x=3):3 2 1 4
第三条指令后(x=2):2 3 1 4
【数据范围】
对于30%的数据,1<=n,m<=1000
对于另外30%的数据,n=m,且1~n每个数在x[i]中恰好出现一次。
对于100%的数据,1<=n,m<=100000
c++ 如何用链表存取数据
由于单链表的每个结点都有一个数据域和一个指针域。所以,每个结点可以定义成一个记录。
其中,DATA数据元素,可以为你想要储存的任何数据格式,可以是数组,可以是int,甚至可以是结构体(这就是传说中的结构体套结构体)
NEXT为一个指针,其代表了一个可以指向的区域,通常是用来指向下一个结点,链表的尾部NEXT指向NULL(空),因为尾部没有任何可以指向的空间了
#include<iostream> using namespace std; struct Node{ int data; Node *next; }; Node *head, *p, *r; //r指向链表的当前最后一个结点,可以称为尾指针 int x; int main(){ cin>>x; head=new Node; //申请头结点 r=head; while(x!=-1){ //读入的数非-1 p=new Node; //否则,读入一个新结点 p->data=x; //把数据放入数据域 p->next=NULL; // 先把当前这个结点的指针域变为NULL r->next=p; //把新结点链接 接到前面的链表中(p可以认为是一个结点的头指针), r=p; //尾指针后移一个 cin>>x; } return 0; }
【写法2】
//声明节点结构 typedef struct Link{ int elem;//存储整形元素 struct Link *next;//指向直接后继元素的指针 }link; //创建链表的函数 link * initLink(){ link * p=(link*)malloc(sizeof(link));//创建一个头结点 link * temp=p;//声明一个指针指向头结点,用于遍历链表 //生成链表 for (int i=1; i<5; i++) { //创建节点并初始化 link *a=(link*)malloc(sizeof(link)); a->elem=i; a->next=NULL; //建立新节点与直接前驱节点的逻辑关系 temp->next=a; temp=temp->next; } return p; }