数据结构(三)算法

数据结构(三)算法

要点:解决问题方法的效率,跟算法的巧妙程度有关

思考:如何让算法更巧妙

01 如何空间的利用效率

参考:实现多项式的两种算法

java 复制代码
public static double f1(int n,double[] a,double x) {
		double rs=a[0];
		for (int i = 1; i < a.length; i++) {
			rs+=a[i]*Math.pow(x, i);
		}
		return rs;
	}
	
public static double f2(int n,double[] a,double x) {
		double rs=a[n];
		for (int i = n; i >0; i--) {
			rs=a[i-1]+rs*x;
		}
		return rs;
	}
	

02 案例:实现多项式的两种算法

1.循环相加

  • 一般的解决方式,直观的写法
java 复制代码
public static double f1(int n,double[] a,double x) {
		double rs=a[0];
		for (int i = 1; i < a.length; i++) {
			rs+=a[i]*Math.pow(x, i);
		}
		return rs;
	}

2.合并同类型相加

  • 不使用冥函数,仅用加减法
java 复制代码
public static double f2(int n,double[] a,double x) {
		double rs=a[n];
		for (int i = n; i >0; i--) {
			rs=a[i-1]+rs*x;
		}
		return rs;
	}

二者对比

  • 但x为1.1,数组a为1到9时,执行10万次,第一个函数的执行时间是第二个函数的1000倍
  • 但x为1.1,数组a为1到9时,执行100万次,第一个函数的执行时间是第二个函数的1万倍

03 我的总结

  • 提高解决问题方法的效率,要提高算法的巧妙程度,减少计算量,用更多的加减法代替乘除法
相关推荐
JeffersonZU17 分钟前
【数据结构】2-3-2 单链表的插入删除
数据结构
m0_7382065421 分钟前
嵌入式学习的第二十二天-数据结构-栈+队列
数据结构·学习
远瞻。1 小时前
【论文阅读】人脸修复(face restoration ) 不同先验代表算法整理2
论文阅读·算法
先做个垃圾出来………4 小时前
哈夫曼树(Huffman Tree)
数据结构·算法
phoenix@Capricornus6 小时前
反向传播算法——矩阵形式递推公式——ReLU传递函数
算法·机器学习·矩阵
Inverse1626 小时前
C语言_动态内存管理
c语言·数据结构·算法
数据与人工智能律师6 小时前
虚拟主播肖像权保护,数字时代的法律博弈
大数据·网络·人工智能·算法·区块链
wuqingshun3141597 小时前
蓝桥杯 16. 外卖店优先级
c++·算法·职场和发展·蓝桥杯·深度优先
YouQian7727 小时前
2025春训第十九场
算法
CodeJourney.7 小时前
基于MATLAB的生物量数据拟合模型研究
人工智能·爬虫·算法·matlab·信息可视化