第三周作业

本文介绍了一个寻找具有最大和的子数组的算法实现过程,通过遍历整数数组并计算连续子数组的和,找出最大子数组及其总和。文章提供了C语言代码示例,包括读取和写入文件的操作。

本周请大家完成上周挑战作业的第一部分:给定一个整数数组(包含正负数),找到一个具有最大和的子数组,返回其最大的子数组的和。
例如:[1, -2, 3, 10, -4, 7, 2, -5]的最大子数组为[3, 10, -4, 7, 2]

输入:

请建立以自己英文名字命名的txt文件,并输入数组元素数值,元素值之间用逗号分隔。

输出

在不删除原有文件内容的情况下,将最大子数组以及子数组的和写入文件。

 实验代码

 #include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
 {
   FILE *fp;
   int i,j,n=8,b,c,max,sum;
   int a[8];
   if((fp=fopen("F:\\C\\liujin.txt","w+"))==NULL)
   {
    printf("File open error!\n");
    exit(0);
   }
   for(i=0;i<8;i++)
       {
    scanf("%d",&a[i]);
   }

       for(i=0;i<n;i++)
      {
      sum=0;
      for(j=i;j<n;j++)
      {
        sum+=a[j];
        if(max<sum)
            {
        max=sum;
    }
   }
  for(i=0;i<n;i++)
  {
    sum=0;
    for(j=i;j<n;j++)
    {
        sum+=a[j];
        if(sum==max)
        {
            b=i;
            c=j;
            break;
        }
    }
   } 
   for(i=b;i<=c;i++)
   {
    fprintf(fp,"%d ",a[i]);
    printf("%d ",a[i]);
   }
  fprintf(fp,"\n%d",max);
  printf("\n%d",max);
  if(fclose(fp))
  {
    printf("Can not close the file!\n");
    exit(0);
   } 
   return 0;
       }
   }
设计思路
  

 

3,遇到的问题及解决办法

在将数据写入文件时,尝试将数组整体输入失败如:fprintf(FP,"%d,",Array[e]);、、、fputs(Array,FP);

4,运行结果截图

 

 

转载于:https://www.cnblogs.com/liu99/p/10540880.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值