echo_chenchen 2022-10-05 09:51 采纳率: 80.2%
浏览 18
已结题

想知道这个质因数分解为什么错了



#include<stdio.h>
int fun(int n,int a[100]);
int isprime(int numble);
int isprime(int numble)
{
    int i=0;
    int flag=0;
    for(i=2;i<numble;i++)
    {
      if(numble%i==0)
     {
      flag=1;
     }
    }
    return flag;
}
int fun(int n,int a[100])
{
  int i=0;
  int j=0;
  for(i=2;i<n/2;i++)
  {
    while(n%i==0)
   {
     for(j=0;j<n;j++)
     {
      a[j]=i;
     }
   }
  }
}
int main()
{
    int n=0;
    int c=0;
    int b[100]={0};
    scanf("%d",&n);
    if(isprime(n))
    {
        fun(n,b[100]);
        printf("%d=%d",n,b[0]);
        int i=2;
        while(b[i]!='\0')
      {
        printf("*%d",b[i]);
        i++;
      }


    }
    else
    {printf("It is a prime number");}

}

想知道这个质因数分解为什么错了

  • 写回答

1条回答 默认 最新

  • 快乐鹦鹉 2022-10-05 09:53
    关注

    fun(n,b);调用fun函数,传递的是b,不是b[100]
    在定义数组的时候 int b[100]表示100个整型的数组,而使用数组时如果写b[100],则表示b数组的第100个元素。但b数组的下标范围是0到99,所以b[100]是越界访问,因此是错误的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 10月13日
  • 已采纳回答 10月5日
  • 创建了问题 10月5日