链接地址:

Poj:http://poj.org/problem?id=1044

OpenJudge:http://bailian.openjudge.cn/practice/1044/

题目:

总时间限制:
1000ms
内存限制:
65536kB
描述
There are rumors that there are a lot of computers having a problem with the year 2000. As they use only two digits to represent the year, the date will suddenly turn from 1999 to 1900. In fact, there are also many other, similar problems. On some systems, a 32-bit integer is used to store the number of seconds that have elapsed since a certain fixed date. In this
way, when 2^32 seconds (about 136 Years) have elapsed, the date will jump back to whatever the fixed date is.
Now,
what can you do about all that mess? Imagine you have two computers C1
and C with two different bugs: One with the ordinary Y2K-Bug (i. e.
switching to a1 := 1900 instead of b1 := 2000) and one switching to a2
:= 1904 instead of b2 := 2040. Imagine that the C1 displays the year y1
:= 1941 and C2 the year y2 := 2005. Then you know the following
(assuming that there are no other bugs): the real year can't be 1941,
since, then, both computers would show the (same) right date. If the
year would be 2005, y1 would be 1905, so this is impossible, too.
Looking only at C1 , we know that the real year is one of the following:
1941, 2041, 2141, etc. We now can calculate what C2 would display in
these years: 1941, 1905, 2005, etc. So in fact, it is possible that the
actual year is 2141.
To calculate all this manually is a lot of
work. (And you don't really want to do it each time you forgot the
actual year.) So, your task is to write a program which does the
calculation for you: find the first possible real year, knowing what
some other computers say (yi) and knowing their bugs (switching to ai
instead of bi ). Note that the year ai is definitely not after the year
the computer was built. Since the actual year can't be before the year
the computers were built, the year your program is looking for can't be
before any ai .
输入
The input file contains several test cases, in which the actual
year has to be calculated. The description of each case starts with a
line containing an integer n (1 <= n <= 20), the number of
computers. Then, there is one line containing three integers yi,ai,bi
for each computer (0 <= ai <= yi < bi < 10000). yi is the
year the computer displays, bi is the year in which the bug happens (i.
e. the first year which can't be displayed by this computer) and ai is
the year that the computer displays instead of bi .
The input is terminated by a test case with n = 0. It should not be processed.
输出
For each test case, output output the line "Case #k:", where k is
the number of the situation. Then, output the line "The actual year is
z.", where z is the smallest possible year (satisfying all computers and
being greater or equal to u). If there is no such year less than 10000,
output "Unkown bugs detected.". Output a blank line after each case.
样例输入
2
1941 1900 2000
2005 1904 2040
2
1998 1900 2000
1999 1900 2000
0
样例输出
Case #1:
The actual year is 2141. Case #2:
Unknown bugs detected.
来源
Mid-Central European Regional Contest 1999

思路:

水题,简单遍历

代码:

 #include <iostream>
#include <cstdio>
using namespace std; int main()
{
int n,i;
int count = ;
int temp_y;
scanf("%d",&n);
while(n!=)
{ int *arr_a = new int[n];
int *arr_b = new int[n];
int *arr_y = new int[n]; for(i =; i < n; i++) scanf("%d%d%d",&arr_y[i],&arr_a[i],&arr_b[i]);
temp_y = arr_y[];
while(temp_y < )
{
for(i = ;i < n; i++)
{
if((temp_y < arr_y[i]) || (temp_y - arr_y[i]) % (arr_b[i] - arr_a[i]) != ) break;
}
if(i >= n) break;
temp_y = temp_y + (arr_b[] - arr_a[]);
}
if(temp_y < ) printf("Case #%d: \nThe actual year is %d.\n",++count,temp_y);
else printf("Case #%d:\nUnknown bugs detected.\n",++count);
printf("\n"); delete [] arr_a;
delete [] arr_b;
delete [] arr_y; scanf("%d",&n);
}
return ;
}

OpenJudge / Poj 1044 Date bugs C++的更多相关文章

  1. POJ 1044: Date bugs

    题目描述 There are rumors that there are a lot of computers having a problem with the year 2000. As they ...

  2. POJ1044 Date bugs

    题目来源:http://poj.org/problem?id=1044 题目大意: 与众所周知的”千年虫“类似,某些计算机上存在日期记录的bug.它们的时钟有一个年份周期,每当到达最大值时,就会自动跳 ...

  3. OpenJudge / Poj 2141 Message Decowding

    1.链接地址: http://poj.org/problem?id=2141 http://bailian.openjudge.cn/practice/2141/ 2.题目: Message Deco ...

  4. OpenJudge/Poj 2105 IP Address

    1.链接地址: http://poj.org/problem?id=2105 http://bailian.openjudge.cn/practice/2105 2.题目: IP Address Ti ...

  5. OpenJudge/Poj 2027 No Brainer

    1.链接地址: http://bailian.openjudge.cn/practice/2027 http://poj.org/problem?id=2027 2.题目: 总Time Limit: ...

  6. OpenJudge/Poj 2013 Symmetric Order

    1.链接地址: http://bailian.openjudge.cn/practice/2013 http://poj.org/problem?id=2013 2.题目: Symmetric Ord ...

  7. OpenJudge/Poj 1088 滑雪

    1.链接地址: bailian.openjudge.cn/practice/1088 http://poj.org/problem?id=1088 2.题目: 总Time Limit: 1000ms ...

  8. OpenJudge/Poj 2001 Shortest Prefixes

    1.链接地址: http://bailian.openjudge.cn/practice/2001 http://poj.org/problem?id=2001 2.题目: Shortest Pref ...

  9. OpenJudge/Poj 2000 Gold Coins

    1.链接地址: http://bailian.openjudge.cn/practice/2000 http://poj.org/problem?id=2000 2.题目: 总Time Limit: ...

随机推荐

  1. JS基础DOM篇之一:何为DOM?

    近日在园子看了一篇文章,一位前端负责人问应聘者何为DOM事件流的三个阶段,我当时一看也是懵圈,于是强迫症复发,遂想要搞清楚它.谁知在查资料的过程中发现有好多关于DOM的概念也是模糊不清,便决定继续延伸 ...

  2. 【转】Netty那点事(四)Netty与Reactor模式

    [原文]https://github.com/code4craft/netty-learning/blob/master/posts/ch4-reactor.md 一:Netty.NIO.多线程? 时 ...

  3. postfix反垃圾邮件说明

    参考地址:http://guailele.blog.51cto.com/1156442/780223 1.打开 smtp 的认证模块 在/etc/postfix/main.cf文件最后加上:   sm ...

  4. Oracle VM Virtual Box 4.3 小巧精悍的虚拟机软件

    https://www.virtualbox.org/wiki/Downloads Download VirtualBox Here, you will find links to VirtualBo ...

  5. [AngularJS] Reusable directive, require from parent controller

    Glorious Directives for Our Navigation NoteWrangler navigation has now been broken into two parts: t ...

  6. ios 界面间跳转方法总结

    接触ios也有一段时间了,偶然间,我们公司的技术总监兼我的导师,问我,你可知道,界面间的跳转有几种方式?我说出了两种,但是也有点含糊其辞,于是我就想一定要找个时间总结一下.有句话说的好,“前人种树,后 ...

  7. Android 自学之相对布局 RelativeLayout

    相对布局(RelativeLayout),相对布局容器内子组件的位置总是相对兄弟组件.父容器来决定的. RelativeLayout的XML属性及相关方法说明 XML属性 相关方法 说明 androi ...

  8. 这五个题你懂了javascript你就入门了

    1. if (!("a" in window)) { var a = 1; } alert(a); 阅读代码:如果window不包含属性a,就声明一个变量a,然后赋值为1,最后弹出 ...

  9. 排序并获取index的顺序

    //排序并获取index的顺序:4,7,2,9-->9,7,4,2-->4,2,1,3 Array.prototype.getIndex=function(){ var orderLeng ...

  10. linux 远程工具

    SecureCRT SecureCRT官网地址:http://www.vandyke.com/products/securecrt/ Xmanager官方网址:http://www.netsarang ...