主题:会做本题的朋友,请回帖,帮帮忙了 ACM 浙大
jiayanli
[专家分:0] 发布于 2006-07-16 18:35:00
我把程序已写了部分,但是总是 wrong answer
学长们帮帮我吧,我现在急着用啊,谢谢!
我编的部分程序如下: (用c++语言编的,输出结果有点出入)
#include<iostream.h>
int main()
{
double Upcount,Downcount;
int Data[30],Count,N,Flag,uc,dc;
while(cin>>N&&N)
{
Count=0;Flag=1;uc=0;dc=0;
Upcount=0.0;Downcount=0.0;
Data[Count++]=N;
while(cin>>N&&N)
{
Data[Count++]=N;
if(Data[Count-1]!=Data[Count-2])
Flag=0;
}
if(Flag)
{
cout<<Upcount<<" "<<Downcount;
}
else
{
int step=0;
for(int i=0;i<=Count-1;)
{
if(Data[i]==Data[i+1])
{
while(Data[i]==Data[i+1])
{
i++;
step++;
if(i>=Count-1) break;
}
}
if(Data[i]<Data[i+1])
{
uc++;
while(Data[i]<=Data[i+1])
{
Upcount+=1.0;
i++;
if(i>=Count-1) break;
}
if(step)
{
Upcount=Upcount+step;
step=0;
}
}
if(Data[i]>Data[i+1])
{
dc++;
while(Data[i]>=Data[i+1])
{
Downcount+=1.0;
i++;
if(i>=Count-1) break;
}
if(step)
{
Downcount=Downcount+step;
step=0;
}
}
step=0;
}
if(uc)
Upcount/=uc;
if(dc)
Downcount/=dc;
cout<<Upcount<<" "<<Downcount;
}
}
return 0;
}
回复列表 (共4个回复)
沙发
rickone [专家分:15390] 发布于 2006-07-16 19:05:00
题目是什么啊~~
板凳
宽 [专家分:150] 发布于 2006-07-16 23:58:00
acm我也在做,你的zju的题号是多少?
3 楼
jiayanli [专家分:0] 发布于 2006-07-17 11:05:00
题号是:1338
题目如下:
Up and Down Sequences
--------------------------------------------------------------------------------
Time limit: 1 Seconds Memory limit: 32768K
Total Submit: 237 Accepted Submit: 150
--------------------------------------------------------------------------------
The quality of pseudo random-number generators used in some computations, especially simulation, is a significant issue. Proposed generation algorithms are subjected to many tests to establish their quality, or, more usually, their lack of it. One of the common tests is the run test.
In this test, sequences are tested for ``runs up" and ``runs down."
We will examine series of data values for the ``Up" and ``Down" sequences each series contains.
Within a series, an ``Up" sequence continues as long as each data-value received is not less than the previous data-value. An ``Up" sequence terminates when a data-value received is less than the previous data-value received.
A ``Down" sequence continues as long as each data-value received is not greater than the previous data-value. A ``Down" sequence terminates when a data-value received is greater than the previous data-value received.
An ``Up" sequence can be initiated by the termination of a ``Down" sequence and vice versa. (Sequences initiated in this manner have length one at this initiation point.)
All the initial data-values are part of an ``Up" sequence, and contribute to its length, if the first deviation of the data-values is upwards.
All the initial data-values are part of a ``Down" sequence, and contribute to its length, if the first deviation of the data-values is downwards.
If the data-values received don't allow classification as either an ``Up" or a ``Down" sequence, the data should be considered to have neither sequence.
Find the average length of both the ``Up" and the ``Down" sequences encountered for each input line in the data file. Report these average lengths as each input line is processed.
Input
Each of the separate series to be examined is contained on a single line of input.
Each series to be analyzed consists of at least one and no more than 30 unsigned, non-zero integers. Each integer in a series has at least one digit and no more than four digits. The integers are separated from each other by a single blank character. Each of the series will be terminated by a single zero (0) digit. This terminator should not be considered as being part of the series being analyzed.
The set of series to be analyzed is terminated by a single zero (0) digit as the input on a line. This terminator should not be considered to be a series, and no output should be produced in response to its encounter.
Output
A line with two real values is to be emitted for each input data set encountered. It must begin with the message ``Nr values = N: ", where N is the number of input data in the line; and then to continue with the average values for runs.
First, the average ``Up" run length, then the average ``Down" run length. Separate these values with a space.
Answers must be rounded to six digits after the decimal point.
Sample Input
1 2 3 0
3 2 1 0
1 2 3 2 1 0
2 2 2 2 3 0
4 4 4 4 3 0
4 4 4 3 3 3 3 0
4 4 4 3 3 3 4 0
5 5 5 5 0
1 2 3 2 3 4 5 0
0
Sample Output
Nr values = 3: 2.000000 0.000000
Nr values = 3: 0.000000 2.000000
Nr values = 5: 2.000000 2.000000
Nr values = 5: 4.000000 0.000000
Nr values = 5: 0.000000 4.000000
Nr values = 7: 0.000000 6.000000
Nr values = 7: 1.000000 5.000000
Nr values = 4: 0.000000 0.000000
Nr values = 7: 2.500000 1.000000
4 楼
jiayanli [专家分:0] 发布于 2006-07-17 11:14:00
我把程序已写了部分,但是总是 wrong answer
学长们帮帮我吧,我现在急着用啊,谢谢!
我编的部分程序如下: (用c++语言编的,输出结果有点出入)
#include<iostream.h>
int main()
{
double Upcount,Downcount;
int Data[30],Count,N,Flag,uc,dc;
while(cin>>N&&N)
{
Count=0;Flag=1;uc=0;dc=0;
Upcount=0.0;Downcount=0.0;
Data[Count++]=N;
while(cin>>N&&N)
{
Data[Count++]=N;
if(Data[Count-1]!=Data[Count-2])
Flag=0;
}
if(Flag)
{
cout<<Upcount<<" "<<Downcount;
}
else
{
int step=0;
for(int i=0;i<=Count-1;)
{
if(Data[i]==Data[i+1])
{
while(Data[i]==Data[i+1])
{
i++;
step++;
if(i>=Count-1) break;
}
}
if(Data[i]<Data[i+1])
{
uc++;
while(Data[i]<=Data[i+1])
{
Upcount+=1.0;
i++;
if(i>=Count-1) break;
}
if(step)
{
Upcount=Upcount+step;
step=0;
}
}
if(Data[i]>Data[i+1])
{
dc++;
while(Data[i]>=Data[i+1])
{
Downcount+=1.0;
i++;
if(i>=Count-1) break;
}
if(step)
{
Downcount=Downcount+step;
step=0;
}
}
step=0;
}
if(uc)
Upcount/=uc;
if(dc)
Downcount/=dc;
cout<<Upcount<<" "<<Downcount;
}
}
return 0;
}
我来回复