链接地址:

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. 封装的多功能多效果的RecyclerView

    开源界有一句很有名的话叫"不要重复发明轮子",当然,我今天的观点不是要反驳这句话,轮子理论给我们的开发带来了极大的便利,.但我想说的是,既要会用轮子,也要知道轮子怎么造,必要的时候 ...

  2. Struts的类型转换

    struts中jsp提交的数据,struts会自动转换为action中的属性类型: 对于基本的数据类型以及日期类型会自动转换: 就像前面那一篇博客的代码封装一样,会把字符串类型传过来的数据转化为相应的 ...

  3. 【转】MyEclipse8.5集成Tomcat7时的启动错误:Exception in thread “main” java.lang.NoClassDefFoundError org/apache/commons/logging/LogFactory

    http://www.cnblogs.com/newsouls/p/4021198.html 今天,安装Tomcat7.0.21后,单独用D:\apache-tomcat-7.0.21\bin\sta ...

  4. C#-获取datagriview选中行中某一列的值

    获取选中行中某一列的值: int index = dg_Product.CurrentRow.Index; //取得选中行的索引 txt_ProductId.Text = dg_Product.Row ...

  5. lightoj1104(数学概率与期望)

    题意: 增加一年有n天; 那么至少有几个人,能够保证至少两个人同一天生日的概率大于等于0.5; 思路: 转化一下题意; 就是求全部人生日都不同的概率小于等于0.5(那么至少两个人同一天就是大于等于0, ...

  6. 04---XML编程整理

    一.XML概述       XML(eXtensible Markup Language),可扩展标记语言,       被设计的宗旨是传输数据,而非显示数据       W3C发布的,目前遵循1.0 ...

  7. IntelliTrace 调试、定位异常

    最近看了一个开源数据库管理,然后没有认真看它的配置环境,想看看是什么东西, 然后发现有类型转换的错误,但是一下子也定位不到哪里出错? 所以对于这种一下子找不到异常在哪里的,可以使用intellitra ...

  8. [Effective C++ --012]复制对象时勿忘其每一个成分

    引言: 在深拷贝和浅拷贝的理解中,我们知道了“拷贝构造函数”一词,并且也了解了它的构成. A(const A& r); // 形式有多种,在这里只列出一个 因此,在值传递的应用场景里,我们可以 ...

  9. php动态调用方法_sux

    <form  action=""> <input type="hidden" name="mod" id="mo ...

  10. 关于SWT中的GridLayout布局方式

    GridLayout 布局的功能非常强大,也是笔者常用的一种布局方式.GridLayout是网格式布局,它把父组件分成一个表格,默认情况下每个子组件占据一个单元格的空间,每个子组件按添加到父组件的顺序 ...