鱼C论坛

 找回密码
 立即注册
查看: 8484|回复: 6

PTA运行超时的问题

[复制链接]
发表于 2018-12-18 08:48:03 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 想学编程的Noob 于 2018-12-18 08:49 编辑

本题要求实现一个函数,计算阶数为n,系数为a[0] ... a[n]的多项式f(x)=a[i]*x^i从i=1->i=n的和 在x点的值。
函数接口定义:
double f( int n, double a[], double x );
其中n是多项式的阶数,a[]中存储系数,x是给定点。函数须返回多项式f(x)的值。
裁判测试程序样例:
#include <stdio.h>

#define MAXN 10

double f( int n, double a[], double x );

int main()
{
    int n, i;
    double a[MAXN], x;
       
    scanf("%d %lf", &n, &x);
    for ( i=0; i<=n; i++ )
        scanf(“%lf”, &a[i]);
    printf("%.1f\n", f(n, a, x));
    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:
2 1.1
1 2.5 -38.7


输出样例:
-43.1

[b]我的代码[/b]
double f( int n, double a[], double x )
{
  double fx = a[0];
  for(int i = 1;i<=n;i++)
  {
      for(int j=1;j<=i;j++)
      {
        a[i] *= x;
      }
      fx += a[i];   
  }
  return fx;
}
答案的测试点都是对的,但最后一个测试点说运行时超时可前两个时间加起来都不到10ms要求是400ms,这是为什么求解
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-12-18 13:20:44 | 显示全部楼层
#include <stdio.h>

#define MAXN 10

double f( int n, double a[], double x );

int main()
{
        freopen("C:\\Users\\zhengsun\\Desktop\\function.txt","r", stdin);
    int n, i;
    double a[MAXN], x;
        
    scanf("%d %lf", &n, &x);
    for ( i=0; i<=n; i++ ) //系数
    scanf("%lf", &a[i]);
    printf("%.1f\n", f(n, a, x));
    return 0;
}
double f( int n, double a[], double x )
{
        int i, j;
  double fx = a[0]; //常数
  for(i = 1; i<=n ; i++)
  {
      for(j=1;j<=i;j++)
      {
        a[i] *= x;
      }
      fx += a[i];   
  }
  return fx;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-18 13:22:03 | 显示全部楼层
提一下,建议题主不要在输入数组的时候直接用&a,这样很容易错的,&a的意思是取数组a的地址,而且后面的函数也要用数组元素啊!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-20 18:28:37 | 显示全部楼层
lemon3 发表于 2018-12-18 13:20
#include

#define MAXN 10

程序不是一抹一样吗。。。
&a是题目给的程序自带的不是我输入的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-20 21:23:28 | 显示全部楼层
题目有要求你不动给的代码吗?我改了一下好像可以运行
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-21 13:46:30 | 显示全部楼层
lemon3 发表于 2018-12-20 21:23
题目有要求你不动给的代码吗?我改了一下好像可以运行

是不可以动的 只要求写出下面的子函数体实现这个功能并与主函数相符合。运行时没有问题只是运行时间超过标准了
我想问是不是有什么可以增加效率的方法减少运行时间
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-21 14:48:04 | 显示全部楼层
嗯,知道了,我再看一下!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-3 02:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表