鱼C论坛

 找回密码
 立即注册
查看: 539|回复: 1

这个函数在传参的时候传错了吗?

[复制链接]
发表于 2023-11-22 09:12:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我想传递的是一个数组,其中chucun和chucun1貌似错误
int chucun0[2];

int yuefen(int fenzi, int fenmu)//较简便的一个约分函数,功能并不完全
{
        double fenmujisuan;
        int i;
        int z;
        int y;
        int x;
        int fenmuchucun[999];
        int fenzichucun[999];
        int jiancha[999];

        fenmujisuan = fenmu / fenzi;
        if (fenmujisuan == (int)fenmujisuan)
        {
                fenzi = fenzi / fenmujisuan;
                fenmu = fenmu / fenmujisuan;
                goto end;
        }
        for (i = 1, z = 0;i <= (fenmu / 2); i++)//区分分母是否为质数
        {
                if (fenmu % i == 0)
                {
                        fenmuchucun[z] = i;
                        z++;
                }
        }
        for (i = 1, z = 0;i <= (fenzi / 2); i++)//区分分子是否为质数
        {
                if (fenzi % i == 0)
                {
                        fenzichucun[z] = i;
                        z++;
                }
        }
        for (i = 0, x = 0;i <= z;i++)
        {
                for (y = 0;y <= z;y++)
                {
                        if (fenmuchucun[i] == fenzichucun[y])
                        {
                                jiancha[x] = fenmuchucun;
                                x++;
                        }
                }
        }
        if(x==0)
        {
                goto end;
        }
        fenzi = fenzi / jiancha[x - 1];
        fenmu = fenmu / jiancha[x - 1];
end:
        //printf("%d/%d", fenzi, fenmu);
        chucun0[0] = fenzi;
        chucun0[1] = fenmu;
        return(*chucun0);
}

int tongfen_jia(int fenzi1, int fenmu1, int fenzi2, int fenmu2)
{
        int fenzi3;
        int fenzi4;
        int fenzi;
        int fenmu;
        fenmu = fenmu1 * fenmu2;
        fenzi3 = fenzi1 * fenmu2;
        fenzi4 = fenzi2 * fenmu1;
        fenzi = fenzi3 + fenzi4;
        return(yuefen(fenzi, fenmu));
}

int tongfen_jian(int fenzi1, int fenmu1, int fenzi2, int fenmu2)
{
        int fenzi3;
        int fenzi4;
        int fenzi;
        int fenmu;
        fenmu = fenmu1 * fenmu2;
        fenzi3 = fenzi1 * fenmu2;
        fenzi4 = fenzi2 * fenmu1;
        if (fenzi3 > fenzi4)
        {
                fenzi = fenzi3 - fenzi4;
        }
        else
        {
                fenzi = fenzi4 - fenzi3;
        }
        return(yuefen(fenzi, fenmu));
}
double jisuan(int* xuanze)
{
        
        int yangbenkongjian = 1;
        int switch1;
        int fenzi[5] = { 0 };
        int fenmu[5] = { 1,1,1,1,1 };
        double gailv[5] = { 0 };
        int chucun[2];
        int chucun1[2];
//************这里要做的是检测知道的数量然后对不同情况进行计算*//////////////////////////
        //**********这里有想到一个更简单的办法,但是需要点技术力*///////
        if ((xuanze[1] && xuanze[2] && xuanze[3]) == 1)
        {
                printf("输入你知道的P(A)的概率的分子和分母,格式为分子/分母\n");
                scanf_s("%d/%d", &fenzi[0], &fenmu[0]);
                gailv[0] = (double)fenzi[0] / fenmu[0];
                printf("输入你知道的P(B)的概率的分子和分母,格式为分子/分母\n");
                scanf_s("%d/%d", &fenzi[1], &fenmu[1]);
                gailv[1] = (double)fenzi[1] / fenmu[1];
                printf("输入你知道的P(A-B)的概率的分子和分母,格式为分子/分母\n");
                scanf_s("%d/%d", &fenzi[2], &fenmu[2]);
                gailv[2] = (double)fenzi[2] / fenmu[2];
                gailv[4] = gailv[0] - gailv[2];//P(AB)
                gailv[3] = gailv[0] + gailv[1] - gailv[4];//P(A+B)
                printf("P(A)的概率为 %d/%d,小数化为 %0.3f %%\n", fenzi[0], fenmu[0], gailv[0]);
                printf("P(B)的概率为 %d/%d,小数化为 %0.3f %%\n", fenzi[1], fenmu[1], gailv[1]);
                printf("P(A-B)的概率为 %d/%d,小数化为 %0.3f %%\n", fenzi[2], fenmu[2], gailv[2]);
                *chucun = tongfen_jian(fenzi[0], fenmu[0], fenzi[2], fenmu[2]);
                printf("P(AB)的概率为 %d/%d ,小数化为 %0.3f %%\n", chucun[0], chucun[1], gailv[4]);//P(AB)
                *chucun = tongfen_jia(fenzi[0], fenmu[0], fenzi[1], fenmu[1]);
                *chucun1 = tongfen_jian(chucun[0], chucun[1], fenzi[4], fenmu[4]);
                printf("P(A+B)的概率为 %d/%d ,小数化为 %0.3f %%\n", chucun1[0], chucun1[1], gailv[3]);//P(A+B)
        }
}
void main()
{
        int fenzi1 = 0;
        int fenmu1 = 1;
        int fenzi2 = 0;
        int fenmu2 = 1;
        int xuanze[5] = { -1 };
        for (;;)
        {
                int switch1 = 0;
                printf("输入1进行模拟实验,输入2进入概率计算。\n");
                scanf_s("%d", &switch1);
                if (switch1 == 1)
                {
                        moni();
                }
                else
                {
                        printf("选择已知的数据。\n");
                        printf("1.P(A) 2.P(B) 3.P(A-B) 4.P(A+B) 5.P(AB)\n");
                        printf("已知则输入1,未知则输入-1即可。例如:1,-1,1,-1,1\n");
                        scanf_s("%d,%d,%d,%d,%d", &xuanze[0], &xuanze[1], &xuanze[2], &xuanze[3], &xuanze[4]);
                        jisuan(xuanze);
                }
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 09:12:52 | 显示全部楼层
这段代码存在一些问题。首先,数组 chucun 和 chucun1 没有被正确声明,应该使用 int chucun[2] 和 int chucun1[2] 来声明这两个数组。其次,在函数 jisuan 中, chucun 和 chucun1 被错误地赋值,应该使用 chucun[0] 和 chucun[1] 来赋值。

此外,代码中存在一些不规范的写法,比如使用 goto 语句和未初始化的变量。建议对代码进行重构和优化,以提高可读性和可维护性。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-7 20:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表