Description
Your chemistry lab instructor is a very enthusiastic graduate student who clearly has forgotten what their undergraduate Chemistry 101 lab experience was like. Your instructor has come up with the brilliant idea that you will monitor the temperature of your mixture every minute for the entire lab. You will then plot the rate of change for the entire duration of the lab.
Being a promising computer scientist, you know you can automate part of this procedure, so you are writing a program you can run on your laptop during chemistry labs. (Laptops are only occasionally dissolved by the chemicals used in such labs.) You will write a program that will let you enter in each temperature as you observe it. The program will then calculate the difference between this temperature and the previous one, and print out the difference. Then you can feed this input into a simple graphing program and finish your plot before you leave the chemistry lab.
Input
The input is a series of temperatures, one per line, ranging from -10 to 200. The temperatures may be specified up to two decimal places. After the final observation, the number 999 will indicate the end of the input data stream. All data sets will have at least two temperature observations.
Output
Your program should output a series of differences between each temperature and the previous temperature. There is one fewer difference observed than the number of temperature observations (output nothing for the first temperature). Differences are always output to two decimal points, with no leading zeroes (except for the ones place for a number less than 1, such as 0.01) or spaces.
After the final output, print a line with "End of Output"
Sample Input
10.0 12.05 30.25 20 999
Sample Output
2.05 18.20 -10.25 End of Output
这个题的坑点就是数组的长度,当输入999的时候,跳出循环,结束,输出英文。
但是需要考虑的是数组中只有999的情况,这个时候数组循环的条件就不行了。因此需要
再循环时加一个条件。
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cstring>
const int maxn = 100001;
using namespace std;
int main()
{
int i, l;
double a[maxn];
double b[maxn];
l = 0;
while(scanf("%lf", &a[l]) && a[l] != 999)
{
l++;
}
for(i=1; a[i]!=999 && i<l; i++)
printf("%.2lf\n",a[i]-a[i-1]);
printf("End of Output\n");
return 0;
}