链接地址:

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. ZZTHX-Androidannotations框架联想

    我们首先来看一段代码: 在android开发中findViewById是最常用的一个方法,用来实例化页面上的控件,基本上每个控件都需要调用一次的,加入我们页面上有100个需要使用,那么findView ...

  2. cocos2d-x Touch

    转自:http://codingnow.cn/cocos2d-x/783.html 游戏跟视频最大的区别就是互动,玩家可以操控游戏中的角色,现在的移动设备几乎人手一台,基本上全部都是基于触屏操作的,今 ...

  3. iOS UITabBarItem 选中图的颜色,设置UIimage的渲染模式

    UITbarController之前有在这篇文章讲解:http://www.cnblogs.com/niit-soft-518/p/4447940.html 如果自定义了UITabBarItem的图片 ...

  4. HDU 5074 Hatsune Miku(DP)

    Problem Description Hatsune Miku is a popular virtual singer. It is very popular in both Japan and C ...

  5. Nuget控制台 - 给你的快速添加缺少的包

    利用命令行安装包

  6. ShowcaseView-master

      ShowcaseView.rar

  7. 飘逸的python - 使用dis模块进行代码层次的性能剖析

    http://blog.csdn.net/handsomekang/article/details/41479597?utm_source=tuicool&utm_medium=referra ...

  8. Google实习面试归来

    咱们寝室共有两个人收到面试通知,我和另一哥们G.      今天早上8:30起了个大早,洗漱完毕,简历复印完毕,就和G骑车到达了世贸中   心酒店那儿.真不愧是世贸中心啊,装修就是华丽,连看门的都是印 ...

  9. Java基础知识强化之网络编程笔记20:Android网络通信之 Android常用OAuth登录和分享

    1.  申请百度开发者账号及百度OAuth简介. (1)申请开发者账号: http://developer.baidu.com/ (2)创建项目: http://developer.baidu.com ...

  10. Java安全防御学习笔记V1.0

    Java安全防御学习笔记V1.0http://www.docin.com/p-766808938.html