标签:hdu 数学
题目链接:
HDU:http://acm.hdu.edu.cn/showproblem.php?pid=3303
Problem Description
We believe that every inhabitant of this universe eventually will find a way to live together in harmony and peace; that trust, patience, kindness and loyalty will exist between every living being of this earth; people will find a way to appreciate and cooperate
with each other instead of continuous bickering, arguing and fighting. Harmony -- the stage of society so many people dream of and yet it seems so far away from now ...
Fortunately, the method of unlocking the key to true Harmony is just discovered by a group of philosophers. It is recorded on a strange meteorite which has just hit the earth. You need to decipher the true meaning behind those seemingly random symbols ... More
precisely, you are to write a program which will support the following two kinds of operation on an initially empty set S :
1.
B X : Add number X to set S . The Kth command in the form of B X always happens at time K , and number X does not belong to set S before this operation.
2.
A Y : Of all the numbers in set S currently, find the one which has the minimum remainder when divided by Y . In case a tie occurs, you should choose the one which appeared latest in the input. Report the time when this element is inserted.
It is said that if the answer can be given in the minimum possible time, true Harmony can be achieved by human races. You task is to write a program to help us.
Input
There are multiple test cases in the input file. Each test case starts with one integer T where 1<=T<=40000 . The following T lines each describe an operation, either in the form of ``B X " or ``A Y " where 1<=X , Y<=500000 .
T = 0 indicates the end of input file and should not be processed by your program.
Output
Print the result of each test case in the format as indicated in the sample output. For every line in the form of ``A Y ", you should output one number, the requested number, on a new line; output -1 if no such number can be found. Separate the results of two
successive inputs with one single blank line.
Sample Input
5
B 1
A 5
B 10
A 5
A 40
2
B 1
A 2
0
Sample Output
Source
题意:
就是对一个集合,有两种操作:
1、将某个元素加入集合中;
2、一个是问当前集合中mod y 最小的数,如果有多个,输出最后加入的那个元素,要求的是输出他们加入集合的时间。
代码如下:
(不过此代码在POJ3145上会TLE,大概是由于HDU上的数据比较弱吧,所以就被我无耻的水过去了,等有时间再试试线段树吧!正确解法应该是用线段树)
//#pragma warning (disable:4786)
#include <cstdio>
#include <cmath>
#include <cstring>
#include <string>
#include <cstdlib>
#include <climits>
#include <ctype.h>
#include <queue>
#include <stack>
#include <vector>
#include <utility>
#include <deque>
#include <set>
#include <map>
#include <iostream>
#include <algorithm>
using namespace std;
const double eps = 1e-9;
//const double pi = atan(1.0)*4;
const double pi = 3.1415926535897932384626;
#define INF 1e18
//typedef long long LL;
//typedef __int64 LL;
int a[5000017], b[5000017];
int main()
{
char cc[7];
int t, tt;
int cas = 0;
int cont = 0;
while(scanf("%d",&t) && t)
{
int l = 0;
if(cont)
printf("\n");
cont++;
printf("Case %d:\n",++cas);
while(t--)
{
scanf("%s%d",cc,&tt);
if(cc[0] == 'B')
{
a[l++] = tt;
}
else if(cc[0] == 'A')
{
int flag = 1;
int minn = tt, f = 0;
for(int i = 0; i < l; i++)
{
if(a[i]%tt <= minn)
{
flag = 0;
minn = a[i]%tt;
f = i+1;
}
}
if(flag)
{
printf("-1\n");
}
else
printf("%d\n",f);
}
}
// printf("\n");
}
return 0;
}
HDU 3303 Harmony Forever(数学)
标签:hdu 数学
原文地址:http://blog.csdn.net/u012860063/article/details/39552917