• 2019年春季学期第三周作业


    2019年春季学期第三周作业
    一、本周完成的作业:
    题目1.
    给定一个整数数组(包含正负数),找到一个具有最大和的子数组,返回其最大的子数组的和。

    输入:

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

    在不删除原有文件内容的情况下,将最大子数组以及子数组的和写入文件。
    (1)实验代码:

    include<stdio.h>
    include<string.h>
    include<stdlib.h>
    int main () 
    {
        FILE *fp;      
        int nums[10],i,j,k,l;
        int max=0;
        int sum=0;
        if((fp=fopen("D:\chenxiaoqiang.txt","r+"))==NULL)
    	{
            printf("File open error!
    ");
            exit(0);
        }
    for(i=0;i<8;i++)
    {
        fscanf(fp,"%d",&nums[i]);
        printf("%d ",nums[i]);
    }
    printf("
    ");
       for(i=0;i<8;i++)
       {
                sum=0;
                for(j=i;j<8;j++)
    			{
                    sum+=nums[j];
                    if(sum>max)
                        max=sum;
                }
            }
        for(i=0;i<8;i++)
    	{
            sum=0;
            for(j=i;j<8;j++)
    		{
                sum+=nums[j];
                if(sum==max)
    			{
                    k=i;
                    l=j;
                    break;
                }   
            }
        }
    for(j=k;j<=l;j++)
    {
        printf("%d ",nums[j]);
        fprintf(fp,"%d ",nums[j]);
    }
    printf("
    %d",max);
    fprintf(fp,"%d",max); if(fclose(fp)){
        printf("Can not close the file! 
    ");
        exit(0);
    }
    return 0;
    }
    

    (2)设计思路:

    (3)错误截图:

    问题:文件中输入元素错误。
    解决方法:改正输入元素即可。
    (4)运行结果截图:

    题目2.7-1 判断上三角矩阵
    上三角矩阵指主对角线以下的元素都为0的矩阵;主对角线为从矩阵的左上角至右下角的连线。

    本题要求编写程序,判断一个给定的方阵是否上三角矩阵。

    输入格式:

    输入第一行给出一个正整数T,为待测矩阵的个数。接下来给出T个矩阵的信息:每个矩阵信息的第一行给出一个不超过10的正整数n。随后n行,每行给出n个整数,其间以空格分隔。
    输出格式:

    每个矩阵的判断结果占一行。如果输入的矩阵是上三角矩阵,输出“YES”,否则输出“NO”。
    输出样例:

    2
    3
    1 2 3
    0 4 5
    0 0 6
    2
    1 0
    -8 2
    输出样例:

    YES
    NO
    (1)实验代码:

    #include <stdio.h>  
    int main() 
    {  
    	int t,n,i,j,k;
    	int a[10][10]; 
    	scanf("%d",&t);
    	int count=0;
    	int b[100]={0};
    	for(k=0; k<t; k++){
    		scanf("%d",&n);
    		for(i=0; i<n; i++){
    			for(j=0; j<n; j++){
    				scanf("%d",&a[i][j]);	
    			}		
    		}
    		for(i=0; i<n; i++){
    			for(j=0; j<n; j++){
    				if(i>j && a[i][j] != 0){
    					count++;
    				}
    			}		
    		}
    		if(count==0 ){
        		b[k] = 1;
        	}else{
        		b[k] = 0;
        	}
    	count=0;
    	}
    	for(k=0; k<t; k++){
    		if(b[k]==1){
    			printf("YES
    ");
    		}else{
    			printf("NO
    ");
    		}
    	}
        return 0;  
    }
    

    (2)设计思路:
    第一步:定义所需变量。
    第二步:输入矩阵。
    第三步:据题意循环判断矩阵是否符合条件。
    第四步:输出结果。
    (3)错误截图:

    问题:循环后未重新赋值。
    解决方法:循环后重新赋值count使其重为0。
    (4)运行结果截图:

    自我评价:作业不能拖,不然时间来不及。

  • 相关阅读:
    mysql数据与Hadoop之间导入导出之Sqoop实例
    如何将mysql数据导入Hadoop之Sqoop安装
    大数据场景下数据异构之 Mysql实时写入HBase(借助canal kafka SparkStreaming)
    224 绝对路径与相对路径
    223 File类的常用方法
    222 File类概述
    221 输入输出流概述
    220 多线程总结
    219 线程间通信
    218 线程同步-synchronized
  • 原文地址:https://www.cnblogs.com/leichen210/p/10541501.html
Copyright © 2020-2023  润新知