| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 337 人关注过本帖
标题:动态规划进行三角划分,帮改错
取消只看楼主 加入收藏
逸云飞
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-10-15
结帖率:0
收藏
已结贴  问题点数:20 回复次数:0 
动态规划进行三角划分,帮改错
  
#include <iostream>  
#include<math.h>
using namespace std;   
#define MAXSIZE 100  
 
 double Weight(int a,int b,int c);
struct
{
    int x;
    int y;
}v[MAXSIZE];
int main()
{
    double m[MAXSIZE][MAXSIZE];
    int s[MAXSIZE][MAXSIZE],i,n;
    cout<<"输入多边形顶点个数n:\n";
    cin>>n;
    cout<<"输入顶点坐标:\n";
    for(i=1;i<=n;i++)
    {   cout<<"输入第"<<i<<"个顶点的坐标\n";
        cin>>v[i].x>>v[i].y;
    }
   
    for(int i=1;i<=n;i++)
        m[i][i]=0;
    for(int l=2;l<=n;l++)
    {
        for(int i=1;i<=n-l+1;i++)
        {
            int j=i+l-1;
            m[i][j]=m[i+1][j]+Weight(i-1,i,j);
            s[i][j]=i;
            for(int k=i+1;k<j;k++)
            {
                double q=m[i][k]+m[k+1][j]+Weight(i-1,k,j);
                if(q<m[i][j])
                    {
                        m[i][j]=q;
                        s[i][j]=k;
                    }
            }
        }
    }
   
    cout<<"此多边形的最优三角划分结构为:"<<endl;
    Traceback(1,n,s);
    cout<<"此多边形的最优三角划分值为:"<<m[1][n-1]<<endl;
    system("pause");
   
    return 0;
}



double Weight(int a,int b,int c)
{   double w1,w2;
    if(a+1==b)
         w1=0;
    else
         w1=sqrt((v[b].x-v[a].x)*(v[b].x-v[a].x)+(v[b].y-v[a].y)*(v[b].y-v[a].y));
    if(b+1==c)
         w2=0;
    else
         w2=sqrt((v[c].x-v[b].x)*(v[c].x-v[b].x)+(v[c].y-v[b].y)*(v[c].y-v[b].y));
    return w1+w2;
}

void Traceback(int i,int j,int *s)  
{  
    if(i==j) return;  
    Traceback(i,s[i][j],s);  
    Traceback(s[i][j]+1,j,s);  
    cout<<"三角剖分顶点:V"<<i-1<<",V"<<j<<",V"<<s[i][j]<<endl;  
}  
搜索更多相关主题的帖子: include double 动态 
2013-10-15 21:41
快速回复:动态规划进行三角划分,帮改错
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.036344 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved