0028-数据结构第一天:从算法的复杂度感受开始

目录

一、从1到N的正整数打印:比较算法复杂度

1.循环算法

2.递归

二、多项式在定点x处的值

三、C语言输入和输出


一、从1到N的正整数打印:比较算法复杂度

1.循环算法

#include <stdio.h>
void PrintN( int N );
int main ()
{ int N;
  scanf("%d", &N);
  PrintN( N );
  return 0;
}

void PrintN( int N )  
{ int i ;
  for ( i=1; i<=N; i++ ){
  	printf("%d\n", i );
  }
  return;
}

2.递归

#include <cstdio>
void PrintN2( int N );
int main ()
{ int N;
  scanf("%d", &N);
  PrintN2( N );
  return 0;
}
 
void PrintN2( int N ) 
{ if ( N )
{
    PrintN2( N - 1 );
}

}

结果,直接输出1000000,超出电脑内存范围,程序不再运行。 

二、多项式在定点x处的值

#include <stdio.h>
#include <time.h>
#include <math.h>
clock_t  start, stop;
double duration;
#define MAXN 10
#define MAXk 1e7
double f1( int n, double a[], double x );
double f2( int n, double a[], double x );
int main ()
{ int i;
  double a[MAXN];
  for ( i=0; i<MAXN; i++) a[i] = (double)i;
  
  start = clock();
  for ( i=0; i<MAXk; i++ )
   f1(MAXN-1, a, 1.1);
  stop = clock();
  duration = ((double)(stop - start))/CLK_TCK/MAXk;
  printf("ticks1 = %f\n", (double)(stop - start));
  printf("duration1 = %6.2e\n", duration);
  
  start = clock();
  for ( i=0; i<MAXk; i++ )
   f2(MAXN-1, a, 1.1);
  stop = clock();
  duration = ((double)(stop - start))/CLK_TCK/MAXk;
  printf("ticks2 = %f\n", (double)(stop - start));
  printf("duration2 = %6.2e\n", duration);
    
  return 0;
}

double f1( int n, double a[], double x )
{ 
  int i;
  double p = a[0];
  for ( i=1; i<=n; i++ )
  	p += (a[i] * pow(x, i));  
  return p;
}

double f2( int n, double a[], double x ) 
{ 
  int i;
  double p = a[n];
  for ( i=n; i>0; i-- )
  	p = a[i-1] + x*p;  
  return p;
}


三、C语言输入和输出

#include <stdio.h>

int main()
{
    printf("23+43=%d\n", 23+43);

    return 0;
}

#include <stdio.h>

int main()
{
    int price = 0;

    printf("how money?   ");
    scanf("%d", &price);

    int change = 100 - price;

    printf("give back  %d\n", change);

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值