lagrange and Gauss_Seidel

program lagrange
implicit none
real(8),dimension(:,:),allocatable::a
real(8),dimension(:),allocatable::l
integer::i,j,k,n
real(8)::x_r,y
print,"输入已知点的个数n"
read(
,)n
allocate(a(n,2),l(n))
print
,"顺序输入n个点的坐标值:(x,y)"
read(,)((a(i,j),j=1,2),i=1,n)
print,"输入你想知道的y值所对应的x值:"
read(
,)x_r
call lagrange_cz(n,a,x_r,y)
print
,"当x=",x_r,"y的数值为:",y
pause
end program lagrange
!****************************************************
subroutine lagrange_cz(n,a,x_r,y)
implicit none
integer::i,j,k,n
real(8),dimension(n,2)::a
real(8),dimension(n)::l
real(8)::x_r,y
y=0
do k=1,n
l(k)=1
do i=1,n
if(i/=k)then
l(k)=l(k)(x_r-a(i,1))/(a(k,1)-a(i,1))
endif
end do
y=y+l(k)
a(k,2)
enddo
end subroutine lagrange_cz
============================================
program Gauss_Seidel
implicit none
real(8),dimension(:,:),allocatable::a
real(8),dimension(:),allocatable::b,x,x_k1,x_result
integer::i,j,n
print,"输入维度n"
read(
,)n
allocate(a(n,n),b(n),x(n),x_k1(n),x_result(n))
print
,"输入nn的数组a"
read(
,)((a(i,j),j=1,n),i=1,n)
print
,"n的数组b"
read(,),b
print,"初始数组x0"
read(
,),x
call Gauss_Seidel_dd(n,a,b,x,x_result)
print
,"x的数值为:",x_result
pause
end program Gauss_Seidel
!****************************************************
subroutine Gauss_Seidel_dd(n,a,b,x,x_result) ! 书上迭代法
implicit none
integer::i,j,n,k
real(8),dimension(n,n)::a
real(8),dimension(n)::b,x,x_k1,x_result
real(8)::sum1,sum2
do k=1,100 !迭代次数
do i=1,n
sum1=0
do j=1,i-1
sum1=sum1+a(i,j)x_k1(j)
end do
sum2=0
do j=i+1,n
sum2=sum2+a(i,j)
x(j)
end do
x_k1(i)=(b(i)-sum1-sum2)/a(i,i)
enddo
x=x_k1 !完成一次迭代
enddo
x_result=x
end subroutine Gauss_Seidel_dd

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • program Gauss_Seidelimplicit nonereal(8),dimension(:,:),a...
    简朴_ocean阅读 158评论 0 0
  • Last updated December 5, 2012. Try searching this page fo...
    walterCui阅读 1,143评论 0 2
  • program lie !列主元消去法implicit nonereal(8),dimension(:,:),al...
    简朴_ocean阅读 587评论 0 0
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,605评论 28 53
  • 信任包括信任自己和信任他人 很多时候,很多事情,失败、遗憾、错过,源于不自信,不信任他人 觉得自己做不成,别人做不...
    吴氵晃阅读 6,226评论 4 8