Problem D: 动态的数组
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 5512 Solved: 2003
[ Submit][ Status][ Web Board]
Description
输入N个浮点数,输出其中第m个~第n个数,满足m<n。
-----------------------------------------------------------------------------
你需要编写以下4个函数,完成这个程序:
double* allocate(int n),在动态内存上分配n个元素的double型数组,并返回其首地址。
void input(double* p, int n),向p中输入n个double型数值。
void output(double* p, int n),把长度为n的数组p中符合条件的第m个~第n个元素输出,m和n从标准输入读取。
void release(double* p),释放p所指的动态内存空间。
函数的调用格式见“Append Code”。
Input
输入的第一个整数N(在int范围内),表示后跟N个double类型的浮点数。输入的最后是两个整数m和n,满足m<n,m和n在int范围内,但不一定在1~N之间。
Output
输出第m个~第n个之间的浮点数,每个数占一行。若区间[m,n]和[1,N]没有任何重叠,则输出“no output”。区间[m,n]和[1,N有交集]时,但给出的n超出第N个数的范围,则只需输出到第N个数,m超出范围时同样处理。
Sample Input
201 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 2015 25
Sample Output
151617181920
HINT
Append Code
//这道题最接近ac的,不是wa,而是re,所以你见到RE不要心情崩溃,这个re其实就等于你平常见到的wa,因为这题的RE都是因为数组的边界,要么你干出了a[-10],要么你定义一个数组a[10],你干出了a[15],下面贴代码,主要是边界处理。
在这里补充一下,另外两个结构体的题就不贴了,很水,但是软件工程的作业比课开的早,嗯,作业是和上机一块发的,而上机比上课早......很绝望的现学现卖了3h......
Problem C: 编写函数:复数的运算 (Append Code)
Problem E: 编写函数:两点之间的距离 (Append Code)
就提示一句,一个是->符号,还有一个是typeof 会了这两个基本就成了,俩不是CE就是AC的题,没啥可说的。
下面贴D题的代码:
#include<stdio.h>
#include<string.h>
#include<malloc.h>
double* allocate(int n)
{
double *p=NULL;
p = (double*)malloc(sizeof(double) * n+5);
return p;
}
void input(double* p, int n)
{
int i;
for(i=0; i<n; i++)
{
scanf("%lf",&p[i]);
}
}
void output(double* p, int n)
{
int i=0;
int a,b;
scanf("%d %d", &a, &b);
if(b<=0||a>=n)printf("no output\n");//边界是在此区间内,如果那两个没有交集,嗯,是不输出的。
else
{
if(a<0)a=1;
for(i=a-1;i<b&&i<n;i++)
{
printf("%lg\n",p[i]);
}
}
}
void release(double* p)
{
free(p);
p=NULL;
}
int main()
{
int len;
double *array;
scanf("%d", &len);
array = allocate(len);
input(array, len);
output(array, len);
release(array);
}
/**************************************************************
Problem: 1383
User: 201701060928
Language: C
Result: Accepted
Time:72 ms
Memory:3092 kb
****************************************************************/