24小时热门版块排行榜    

查看: 1388  |  回复: 9

zyj8119

木虫 (著名写手)

[交流] 【求助】为什么我这个程序编译都没有问题,就是运行不出来?【已完结】 已有5人参与

#include
#include
#include
using namespace std;
class sdet
{
private:
        int n;
        double **a,det;
public:
        sdet(int nn)
        {
                int i;
                n=nn;
                a=new double * [n];
                for(i=0;i=new double[n];
        }
        void input();
        void a_det();
        void output();
        sdet()
        {
                int i;
                for(i=0;i;}
                delete[]a;
        }
};

        void sdet::input()
        {
                int i,j;
                char str1[20];
                cout<<"\n 输入文件名:";
                cin>>str1;
                ifstream fin(str1);
                if(!fin)
                {cout<<"\n不能打开这个文件"<                 for(i=0;i                         for(j=0;j>a[j];
                        fin.close();
        }

        void sdet::a_det()
        {
                int i,j,k,is,js;
                double f,q,d;
                f=1.0;det=1.0;
                for(k=0;k<=n-2;k++)
                {
                        q=0.0;
                        for(i=k;i<=n-1;i++)
                        for(j=k;j<=n-1;j++)
                        {
                                d=fabs(a[j]);
                                if(d>q){q=d;is=i;js=j;}
                        }
                        if(q+1.0==1.0)det=0.0;
                        else
                        {
                                if(is!=k)
                                {
                                        f=-f;
                                        for(j=k;j<=n-1;j++)
                                        {
                                                d=a[k][j];a[k][j]=a[is][j];a[is][j]=d;
                                        }
                                }
                                if(js!=k)
                                {
                                        f=-f;
                                        for(j=k;j<=n-1;j++)
                                        {
                                                d=a[js];a[js]=a[k];a[k]=d;
                                        }
                                }
                                det=det*a[k][k];
                                for(i=k+1;i<=n-1;i++)
                                {
                                        d=a[k]/a[k][k];
                                        for(j=k+1;j<=n-1;j++)
                                        {
                                                a[j]=a[j]-d*a[k][j];
                                        }
                                }
                        }
                }
                det=f*det*a[n-1][n-1];
        }

        void sdet:utput()
        {
                char str2[20];
                cout<<"\n输入文件名:";
                cin>>str2;
                ofstream fout (str2);
                if(!fout)
                {cout<<"\n不能打开这个文件"<                 fout<                 cout<                 fout.close();
        }

        void main()
        {
                sdet d(4);
                d.input();
                d.a_det();
                d.output();
        }


文件是这样的:
1   2   3   4

5   6   7   8

9  10  11  12

13  14  15  16

[ Last edited by nono2009 on 2010-6-28 at 12:56 ]
回复此楼

» 猜你喜欢

好好学习,天天向上。
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zyj8119

木虫 (著名写手)

nono2009:建议今后用[code]代码[/code],就不会出现这种情况了。 2010-06-28 12:24:22
void sdet:: output()
好好学习,天天向上。
2楼2010-06-25 01:09:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)

★ ★
zyj8119(金币+1):谢谢参与
resonant(金币+1):感谢参与:-) 2010-06-25 16:54:56
有什么问题呢?至少说下现象吧。
难道你去看医生,只说我病了,不说什么症状,医生就能给你诊断吗?
这年头,怎么那么多人连提问都不会
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
3楼2010-06-25 08:41:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

alexissp

金虫 (正式写手)

干活的


zyj8119(金币+1):谢谢参与
引用回帖:
Originally posted by magic7004 at 2010-06-25 08:41:31:
有什么问题呢?至少说下现象吧。

这么贴谁受得了,呵呵
简单充实
4楼2010-06-25 09:53:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zyj8119

木虫 (著名写手)

就是运行的时候,出现本程序已经关闭啊,什么错误都没有贴出来。
好好学习,天天向上。
5楼2010-06-25 11:42:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

simthhuang

木虫 (小有名气)

★ ★
zyj8119(金币+1):谢谢参与
resonant(金币+1):感谢参与:-) 2010-06-25 16:54:43
d=a[js];a[js]=a[k];a[k]=d;
下标溢出,i = 4!!
一贯知足二目远眺三餐有节四季不懒五谷皆食六欲不张七分忍让八方交往九薄烟断十分坦荡
6楼2010-06-25 12:48:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)


resonant(金币+1):感谢参与:-) 2010-06-25 16:54:26
zyj8119(金币+5):这么小,可以当做0了。 2010-06-25 21:26:51
不知道啊,我能运行的,结果是2.74078e-34
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
7楼2010-06-25 15:56:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

simthhuang

木虫 (小有名气)


余泽成(金币+1):那就再加一分! 2010-06-27 21:34:22
看到版主给加了一分的面子上,再来回复下吧。
首先说明不清楚a_det()函数算法的含义。
其次是该函数肯定的是该算法存在下标溢出,如6楼所述。
最后,我在下标溢出前做了个简单的处理: i--;
运行所得的结果为:-5.24708e-014
一贯知足二目远眺三餐有节四季不懒五谷皆食六欲不张七分忍让八方交往九薄烟断十分坦荡
8楼2010-06-27 21:28:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhangeil04

铁杆木虫 (著名写手)


zyj8119(金币+1):谢谢参与
zyj8119(金币+5):谢谢。。。 2010-06-27 22:15:26
d=a[js];a[js]=a[k];a[k]=d;
下标溢出,i = 4!!
9楼2010-06-27 21:33:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

magic7004

金虫 (职业作家)


zyj8119(金币+6):只有6个 2010-06-28 10:22:55
余泽成(金币+1):谢谢参与应助! 2010-06-28 20:43:32
for(i=k;i<=n-1;i++)
                        for(j=k;j<=n-1;j++)
                        {
                                d=fabs(a[j]);
                                if(d>q){q=d;is=i;js=j;}
                        }
这里第一个for后面貌似少了大括号了,所以后面会溢出。
流氓不可怕,可怕的是流氓有文化,有文化又BH的流氓无敌~~!
10楼2010-06-28 08:37:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 zyj8119 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程(专)一志愿985 初试335求调剂 +3 hiloiy 2026-03-17 4/200 2026-03-21 03:04 by JourneyLucky
[考研] 一志愿中国石油大学(华东) 本科齐鲁工业大学 +3 石能伟 2026-03-17 3/150 2026-03-21 02:22 by JourneyLucky
[考研] 一志愿武理材料305分求调剂 +6 想上岸的鲤鱼 2026-03-18 7/350 2026-03-21 01:03 by JourneyLucky
[考研] 271材料工程求调剂 +8 .6lL 2026-03-18 8/400 2026-03-21 00:58 by JourneyLucky
[考研] 311求调剂 +5 冬十三 2026-03-18 5/250 2026-03-21 00:16 by JourneyLucky
[考研] 22408 344分 求调剂 一志愿 华电计算机技术 +4 solanXXX 2026-03-20 4/200 2026-03-20 23:49 by alg094825
[考研] 一志愿西南交通 专硕 材料355 本科双非 求调剂 +5 西南交通专材355 2026-03-19 5/250 2026-03-20 21:10 by JourneyLucky
[考研] 295复试调剂 +8 简木ChuFront 2026-03-19 8/400 2026-03-20 20:44 by zhukairuo
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +5 Charlieyq 2026-03-19 5/250 2026-03-20 20:35 by JourneyLucky
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +5 @taotao 2026-03-20 5/250 2026-03-20 20:16 by JourneyLucky
[考研] 求调剂 +3 @taotao 2026-03-20 3/150 2026-03-20 19:35 by JourneyLucky
[考研] 一志愿中国海洋大学,生物学,301分,求调剂 +5 1孙悟空 2026-03-17 6/300 2026-03-19 23:46 by zcl123
[考研] 320求调剂0856 +3 不想起名字112 2026-03-19 3/150 2026-03-19 22:53 by 学员8dgXkO
[考研] 材料工程专硕调剂 +5 204818@lcx 2026-03-17 6/300 2026-03-18 22:55 by 204818@lcx
[考研] 化学工程321分求调剂 +15 大米饭! 2026-03-15 18/900 2026-03-18 14:52 by haxia
[考研] 311求调剂 +11 冬十三 2026-03-15 12/600 2026-03-18 14:36 by 星空星月
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
[考研] 327求调剂 +6 拾光任染 2026-03-15 11/550 2026-03-15 22:47 by 拾光任染
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
信息提示
请填处理意见