亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? newton.cpp

?? Newton插值多項式,這里才用6組數據進行測試.每步詳細記錄計算過程
?? CPP
字號:
//xi		0.5			1.0			1.5			2.0			2.5			3.0
//f(xi)	0.541688	-0.042060	0.375089	0.624706	-0.887597	0.099809
//輸入節點數及節點數據,計算并輸出差商表;
//輸入待使用的插值多項式次數,待求的自變量 x,輸出內插需要選擇的節點及 Newton 插值多項式;
//用 3 次 Newton 插值多項式計算并輸出 f (1.25);
//用 5 次 Newton 插值多項式計算并輸出 f (1.987)。
//
//

#include <stdio.h>
#include <malloc.h>
#include <conio.h>
#include <stdlib.h>
typedef struct vex
{ 
	double x;
	double y;
}vex,*pVex;
void function(pVex dvex,double F[5][5],int style,double x,double vex[],char* Newton,double result);
void main()
{
	int N=6;
	pVex dvex=(pVex)malloc(N*sizeof(vex));
	dvex[0].x=0.5;dvex[0].y=0.541688;
	dvex[1].x=1.0;dvex[1].y=-0.042060;
	dvex[2].x=1.5;dvex[2].y=0.375089;
	dvex[3].x=2.0;dvex[3].y=0.624706;
	dvex[4].x=2.5;dvex[4].y=-0.887597;
	dvex[5].x=3.0;dvex[5].y=0.099809;
	//////////////////////////
	int i,j;
	double F[5][5];
	///////////////////////
	//差商表的形成過程
	for(i=0;i<N-1;i++)
		F[i][0]=(dvex[i+1].y-dvex[i].y)/(dvex[i+1].x-dvex[i].x);
	for(j=1;j<N-1;j++)
		for(i=j;i<N-1;i++)
			F[i][j]=(F[i][j-1]-F[i-1][j-1])/(dvex[i+1].x-dvex[i-j].x);
	/////////////////////////
	printf("下面輸出Newton差商表:\n");
	printf("x值\ty值\t\t一階差商\t二階差商\t三階差商\t四階差商\t五階差商\n");
	printf("%.1f\t%f\n",dvex[0].x,dvex[0].y);
	printf("%.1f\t%f\t%f\n",dvex[1].x,dvex[1].y,F[0][0]);
	printf("%.1f\t%f\t%f\t%f\n",dvex[2].x,dvex[2].y,F[1][0],F[1][1]);
	printf("%.1f\t%f\t%f\t%f\t%f\n",dvex[3].x,dvex[3].y,F[2][0],F[2][1],F[2][2]);
	printf("%.1f\t%f\t%f\t%f\t%f\t%f\n",dvex[4].x,dvex[4].y,F[3][0],F[3][1],F[3][2],F[3][3]);
	printf("%.1f\t%f\t%f\t%f\t%f\t%f\t%f\n",dvex[5].x,dvex[5].y,F[4][0],F[4][1],F[4][2],F[4][3],F[4][4]);
	/////////////////////////
	double pVex[5]={0,0,0,0,0};
	char pNewton[200]="";
	double result=0;
	////////////////////////////////
	printf("------------------------------------------------------------\n");
	printf("下面用3次Newton插值多項式計算并輸出f(1.125)\n");
	function(dvex,F,3,1.125,pVex,pNewton,result);
	printf("------------------------------------------------------------\n");
	printf("下面用5次Newton插值多項式計算并輸出f(1.987)");
	function(dvex,F,5,1.987,pVex,pNewton,result);
	////////////////////////////////
	printf("------------------------------------------------------------\n");
	printf("下面,請輸入待使用的插值多項式次數,待求的自變量 x\n");
	int nN;float dX;
	for(;;)
	{
		printf("\n待使用的插值多項式次數(輸入0退出程序):");
		scanf("%d",&nN);
		if(nN==0)exit(0);
		while(nN<1||nN>5)
		{
			printf("輸入的次數建議在1~5之間\n");
			scanf("%d",&nN);
		}
		printf("待求的自變量 x:");
		scanf("%f",&dX);
		while(dX<dvex[0].x||dX>dvex[5].x)
		{
			printf("輸入的自變量不在%f和%f之間\n",dvex[0].x,dvex[5].x);
			scanf("%f",&dX);
		}
		printf("下面開始顯示結果\n");

		function(dvex,F,nN,dX,pVex,pNewton,result);
	}
	getch();	
}
void function(pVex dvex,double F[5][5],int style,double x,double vex[],char* Newton,double result)
{
	int i=0;
	int vex_i;
	int j=0;
	switch(style)
	{
	case 1:
		{
			while(x>dvex[i].x)i++;
			printf("\n所選節點為:\n");
			for(vex_i=i-1,j=0;vex_i<i+1;vex_i++,j++)printf("%1.1f\t",vex[j]=dvex[vex_i].x);
			sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)",
					dvex[i-1].y,
					F[i-1][0],dvex[i-1].x
					);
			printf("\n表達式為:%s",Newton);
			result=dvex[i-1].y+F[i-1][0]*(x-dvex[i-1].x);
			printf("\n其f(%.6f)結果為%2.6f\n",x,result);
			break;
		}
	case 2:
		{
			while(x>dvex[i].x)i++;
			if(i==5)
			{
				printf("\n所選節點為:\n%1.1f\t%1.1f\t%1.1f\n",dvex[3].x,dvex[4].x,dvex[5].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)",
					dvex[3].y,
					F[3][0],dvex[3].x,
					F[4][1],dvex[3].x,dvex[4].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[3].y+F[3][0]*(x-dvex[3].x)+F[4][1]*(x-dvex[4].x);
			}
			else
			{
				printf("\n所選節點為:\n");
				for(vex_i=i-1,j=0;vex_i<i+2;vex_i++,j++)printf("%1.1f\t",vex[j]=dvex[vex_i].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)",
					dvex[i-1].y,
					F[i-1][0],dvex[i-1].x,
					F[i][1],dvex[i-1].x,dvex[i].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[i-1].y+F[i-1][0]*(x-dvex[i-1].x)+F[i][1]*(x-dvex[i-1].x)*(x-dvex[i].x);
			}
			printf("\n其f(%.6f)結果為%2.6f\n",x,result);
			break;
		}
	case 3:
		{
			while(x>dvex[i].x)i++;
			//x[0]	y[0]										F[i][j]
			//x[1]	y[1]	F[0][0]
			//x[2]	y[2]	F[1][0]		F[1][1]
			//x[3]	y[3]	F[2][0]		F[2][1]		F[2][2]
			//x[4]	y[4]	F[3][0]		F[3][1]		F[3][2]		F[3][3]
			//x[5]	y[5]	F[4][0]		F[4][1]		F[4][2]		F[4][3]		F[4][4]
			if(i==5||x==4)
			{
				printf("\n所選節點為:\n%1.1f\t%1.1f\t%1.1f\t%1.1f\n",dvex[2].x,dvex[3].x,dvex[4].x,dvex[5].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)",
					dvex[2].y,
					F[2][0],dvex[2].x,
					F[3][1],dvex[2].x,dvex[3].x,
					F[4][2],dvex[2].x,dvex[3].x,dvex[4].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[2].y+F[2][0]*(x-dvex[2].x)+F[3][1]*(x-dvex[2].x)*(x-dvex[3].x)+F[4][2]*(x-dvex[2].x)*(x-dvex[3].x)*(x-dvex[4].x);
			}
			else
			{
				printf("\n所選節點為:\n");
				for(vex_i=i-1,j=0;vex_i<i+3;vex_i++,j++)printf("%1.1f\t",vex[j]=dvex[vex_i].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)",
					dvex[i-1].y,
					F[i-1][0],dvex[i-1].x,
					F[i][1],dvex[i-1].x,dvex[i].x,
					F[i+1][2],dvex[i-1].x,dvex[i].x,dvex[i+1].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[i-1].y+F[i-1][0]*(x-dvex[i-1].x)+F[i][1]*(x-dvex[i-1].x)*(x-dvex[i].x)+F[i+1][2]*(x-dvex[i-1].x)*(x-dvex[i].x)*(x-dvex[i+1].x);
			}
			
			printf("\n其f(%.6f)結果為%2.6f\n",x,result);
			break;
		}
	case 4:
		{
			while(x>dvex[i].x)i++;
			if(i==5||i==4||x==3)
			{
				printf("\n所選節點為:\n%1.1f\t%1.1f\t%1.1f\t%1.1f\t%1.1f\n",dvex[1].x,dvex[2].x,dvex[3].x,dvex[4].x,dvex[5].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)",
					dvex[1].y,
					F[1][0],dvex[1].x,
					F[2][1],dvex[1].x,dvex[2].x,
					F[3][2],dvex[1].x,dvex[2].x,dvex[3].x,
					F[4][3],dvex[1].x,dvex[3].x,dvex[3].x,dvex[4].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[2].y+F[2][0]*(x-dvex[2].x)+F[3][1]*(x-dvex[2].x)*(x-dvex[3].x)+F[4][1]*(x-dvex[2].x)*(x-dvex[3].x)*(x-dvex[4].x);
			}
			else
			{
				printf("\n所選節點為:\n");
				for(vex_i=i-1;vex_i<i+4;vex_i++,j++)printf("%1.1f\t",vex[j]=dvex[vex_i].x);
				sprintf(
					Newton,
					"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)",
					dvex[i-1].y,
					F[i-1][0],	dvex[i-1].x,
					F[i][1],	dvex[i-1].x,	dvex[i].x,
					F[i+1][2],	dvex[i-1].x,	dvex[i].x,	dvex[i+1].x,
					F[i+2][3],	dvex[i-1].x,	dvex[i].x,	dvex[i+1].x,	dvex[i+2].x
					);
				printf("\n表達式為:%s",Newton);
				result=dvex[i-1].y+F[i-1][0]*(x-dvex[i-1].x)+F[i][1]*(x-dvex[i-1].x)*(x-dvex[i].x)+
					F[i+1][2]*(x-dvex[i-1].x)*(x-dvex[i].x)*(x-dvex[i+1].x)+F[i+2][3]*(x-dvex[i-1].x)*(x-dvex[i].x)*(x-dvex[i+1].x)*(x-dvex[i+2].x);
			}
			printf("\n其f(%.6f)結果為%2.6f\n",x,result);
			break;
		}
	case 5:
		{
			printf("\n所選節點為:\n");
			for(j=0;j<6;j++)printf("%1.1f\t",dvex[j].x);
			for(vex_i=0;vex_i<6;vex_i++)vex[i]=dvex[i].x;
			sprintf(
				Newton,
				"f(x)=\n\t\t%f+\n\t\t%f*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)+\n\t\t%f*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)*(x-%1.1f)",
				dvex[0].y,
				F[0][0],dvex[0].x,
				F[1][1],dvex[0].x,dvex[1].x,
				F[2][2],dvex[0].x,dvex[1].x,dvex[2].x,
				F[3][3],dvex[0].x,dvex[1].x,dvex[2].x,dvex[3].x,
				F[4][4],dvex[0].x,dvex[1].x,dvex[2].x,dvex[3].x,dvex[4].x
				);
			printf("\n表達式為:%s",Newton);
			result=dvex[0].y+
				F[0][0]*(x-dvex[0].x)+
				F[1][1]*(x-dvex[0].x)*(x-dvex[1].x)+
				F[2][2]*(x-dvex[0].x)*(x-dvex[1].x)*(x-dvex[2].x)+
				F[3][3]*(x-dvex[0].x)*(x-dvex[1].x)*(x-dvex[2].x)*(x-dvex[3].x),
				F[4][4]*(x-dvex[0].x)*(x-dvex[1].x)*(x-dvex[2].x)*(x-dvex[3].x)*(x-dvex[4].x);
			printf("\n其f(%.6f)結果為%2.6f\n",x,result);
			break;
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费精品视频| 国产亚洲短视频| 久久精品在线观看| 亚洲精品乱码久久久久久| 捆绑调教一区二区三区| 色婷婷av一区二区三区软件 | 岛国一区二区三区| 91麻豆精品国产| 亚洲久草在线视频| 成人国产精品视频| 久久久一区二区三区| 偷偷要91色婷婷| 欧美在线你懂的| 国产精品污www在线观看| 精品在线观看免费| 欧美精品亚洲一区二区在线播放| 国产精品久久久久精k8 | 北岛玲一区二区三区四区| 精品国产精品网麻豆系列| 日韩高清不卡一区| 欧美色网站导航| 亚洲综合在线五月| 在线观看亚洲精品| 1024亚洲合集| 成人毛片在线观看| 亚洲国产精品激情在线观看| 精品午夜一区二区三区在线观看| 制服丝袜日韩国产| 日韩成人午夜电影| 欧美片在线播放| 日韩成人免费在线| 日韩三级伦理片妻子的秘密按摩| 日韩精品成人一区二区三区| 欧美三级中文字| 一区二区三区精密机械公司| 欧美专区亚洲专区| 午夜伦欧美伦电影理论片| 欧美久久一二区| 天涯成人国产亚洲精品一区av| 欧美丰满一区二区免费视频| 日韩av电影一区| 欧美mv日韩mv国产网站app| 另类中文字幕网| 久久久久9999亚洲精品| 高清国产午夜精品久久久久久| 国产女人aaa级久久久级| 99热这里都是精品| 亚洲欧美精品午睡沙发| 欧美亚洲一区二区在线| 日韩影院精彩在线| www国产成人| 成人国产电影网| 亚洲自拍偷拍av| 日韩一区和二区| 国产成a人亚洲精品| 亚洲精品中文在线观看| 欧美精品xxxxbbbb| 国产福利91精品| 一区二区三区日韩精品视频| 欧美精选一区二区| 国产精品18久久久久久久久久久久| 中文字幕日韩一区二区| 91精品办公室少妇高潮对白| 免费成人小视频| 亚洲国产精品ⅴa在线观看| 在线观看免费亚洲| 麻豆国产精品视频| 国产精品家庭影院| 欧美久久久久中文字幕| 国产成人在线免费观看| 亚洲成人午夜影院| 日本一区二区久久| 3d成人动漫网站| 波多野结衣一区二区三区| 午夜精品免费在线| 中文字幕av资源一区| 91麻豆精品国产| 91啪在线观看| 精品亚洲成a人在线观看| 亚洲人成在线观看一区二区| 日韩精品资源二区在线| 色婷婷综合中文久久一本| 狠狠色丁香婷婷综合久久片| 亚洲一区在线观看视频| 国产婷婷精品av在线| 91精品国产品国语在线不卡| 一本色道久久综合精品竹菊| 国产九色sp调教91| 秋霞影院一区二区| 亚洲综合激情小说| 亚洲欧美综合另类在线卡通| 精品福利一区二区三区免费视频| 欧美亚日韩国产aⅴ精品中极品| 国产精品一区二区久久精品爱涩| 亚洲一区影音先锋| 国产精品久久久久一区二区三区 | 国产视频亚洲色图| 91精品国产综合久久婷婷香蕉| 一本到一区二区三区| 成人av在线播放网址| 国产成人免费网站| 国产尤物一区二区在线| 青青草国产成人av片免费| 亚洲午夜激情网页| 有码一区二区三区| 一区二区免费在线| 一区二区三区在线播| 亚洲男女毛片无遮挡| 亚洲欧洲日产国产综合网| 国产精品欧美极品| 欧美激情一区二区三区蜜桃视频| 精品国产91亚洲一区二区三区婷婷| 91精品免费在线| 欧美大片一区二区三区| 欧美一级生活片| 欧美一级久久久| 欧美电视剧免费全集观看| 精品日韩在线一区| 欧美精品一区二区三区高清aⅴ| 日韩一级二级三级| www久久久久| 国产丝袜欧美中文另类| 中文字幕av资源一区| 综合电影一区二区三区 | 美女视频一区二区三区| 青椒成人免费视频| 国产一区二区三区美女| 国产精品中文字幕日韩精品| 大尺度一区二区| 色老汉av一区二区三区| 欧美日高清视频| 精品欧美久久久| 国产精品你懂的| 曰韩精品一区二区| 日韩专区一卡二卡| 国产在线看一区| 成人美女在线观看| 欧美三级乱人伦电影| 精品少妇一区二区三区在线视频| 国产日本欧洲亚洲| 一区二区三区日本| 蜜臀av国产精品久久久久| 高清beeg欧美| 在线观看亚洲成人| 精品成人一区二区三区四区| 中文字幕一区二区在线观看| 午夜精品福利久久久| 精品一区二区三区久久| 99精品黄色片免费大全| 欧美顶级少妇做爰| 国产精品天天摸av网| 视频一区在线播放| 成人夜色视频网站在线观看| 欧美亚一区二区| 久久精品亚洲一区二区三区浴池| 中文字幕一区二区三区四区| 日韩av高清在线观看| 成人av电影在线| 日韩欧美一级二级三级久久久| 国产精品视频在线看| 天堂成人免费av电影一区| 国产精品亚洲人在线观看| 欧美日韩成人在线一区| 国产精品女上位| 毛片一区二区三区| 日本精品裸体写真集在线观看| 亚洲精品一区在线观看| 丝袜美腿亚洲色图| 99精品偷自拍| 国产清纯白嫩初高生在线观看91 | 日韩免费视频一区二区| 18欧美亚洲精品| 国产精品中文字幕欧美| 欧美一二三四区在线| 樱花草国产18久久久久| 福利一区福利二区| 精品久久久久av影院| 亚洲成av人影院| 色www精品视频在线观看| 中文字幕久久午夜不卡| 久久超碰97人人做人人爱| 欧美日韩中文字幕一区二区| 日韩美女视频一区二区 | 综合激情成人伊人| 国产乱人伦精品一区二区在线观看 | 国产欧美日韩久久| 五月婷婷激情综合| 91在线看国产| 国产精品久久久久影院| 岛国一区二区在线观看| 久久精品一区八戒影视| 久久精品av麻豆的观看方式| 欧美人牲a欧美精品| 午夜久久电影网| 欧美少妇一区二区| 午夜精品久久久久影视| 欧美日精品一区视频| 亚洲午夜av在线| 欧美精品一级二级| 日韩不卡一二三区|