zoukankan      html  css  js  c++  java
  • 第四周作业

    7-1 找鞍点 (20 分)

    一个矩阵元素的“鞍点”是指该位置上的元素值在该行上最大、在该列上最小。

    本题要求编写程序,求一个给定的n阶方阵的鞍点。

    输入格式:
    输入第一行给出一个正整数n(1≤n≤6)。随后n行,每行给出n个整数,其间以空格分隔。

    输出格式:
    输出在一行中按照“行下标 列下标”(下标从0开始)的格式输出鞍点的位置。如果鞍点不存在,则输出“NONE”。题目保证给出的矩阵至多存在一个鞍点。

    输入样例1:

    4
    1 7 4 1
    4 8 3 6
    1 6 1 2
    0 7 8 9
    

    输出样例1:

    2 1
    

    输入样例2:

    2
    1 7
    4 1
    

    输出样例2:

    NONE
    

    2、实验代码:

    #include <stdio.h>  
    
    int main()  
    {   	
     
    	 int n,i,j,c=0,b=0,d=0,k=0;
    	 int a[6][6];
    	 scanf("%d",&n);
      
        for(i=0; i<n; i++)  {
            for(j=0; j<n; j++)  {  
                scanf("%d",&a[i][j]);  
            }      	
        }
     
        if(n==1){
            printf("0 0");
        }else{  
            for(i=0; i<n; i++){  
                d=i;   
                for(b=0; b<n; b++) {   
                    if(a[i][c]<=a[i][b]) {  
                        c=b;  
                    }  
                }  
                
                for(j=0; j<n; j++){   
                    if(a[d][c]>a[j][c]){  
                        d=j;  
                        break;  
                    }  
                }  
                
                if(i==d){  
                    k++;  
                    break;  
                }  
            }  
            if(k!=0){
    			printf("%d %d",i,c);  
    	    }
            else {
    			printf("NONE"); 
    	    }
        }  
        return 0;  
      
    } 
     
    

    3、流程图:

    4、调试过程遇到的问题:

    问题1:部分正确,第一个方正不能正确输出,但第二个可以正确输出。

    解决办法:到网上去查找一下再看看他跟你有何不同

    5、运行结果截图:

    7-2 选择法排序 (20 分)

    本题要求将给定的n个整数从大到小排序后输出。

    输入格式:
    输入第一行给出一个不超过10的正整数n。第二行给出n个整数,其间以空格分隔。

    输出格式:
    在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。

    输入样例:

    4
    5 1 7 6
    

    输出样例:

    7 6 5 1
    

    2、实验代码:

    #include<stdio.h>
    int main(void)
    {
    	int n,k,b=0,i=0,s=0;
    	int a[10];
    	scanf("%d",&n);
    	for(k=0;k<n;k++){
    		scanf("%d",&a[k]);
    	}
    	
    	for(k=0;k<n-1;k++){
    	  b=k;
    	  for(i=k+1;i<n;i++){
    	    if(a[i]<a[b]){
    	      b=i;
    	      s=a[k];a[k]=a[b];a[b]=s;
    	    }
    	  }
    	}
    
    	for(k=n-1;k>=0;k--){
    		if(k>0){
    			printf("%d ",a[k]);
    		}
    		else{
    			printf("%d",a[k]);
    		}
    	}
    	return 0;
    }
    

    3、流程图:

    4、调试过程遇到的问题:

    问题1:输出时不是按大到小的顺序。

    解决办法:因为书上那种是小到大的所以我只要输出的时候倒过来。

    5、运行结果截图:

    7-1 冒泡法排序 (10 分)

    输入1个正整数n(1<=n<=10),然后输入n个整数并存放在数组中,将这n个整数从大到小排序后输出,相邻数字间有一个空格,行末不得有多余空格。

    输入格式:
    输入第一行给出一个不超过10的正整数n。第二行给出n个整数,其间以空格分隔。

    输出格式:
    在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。

    输入样例:

    4 
    75 71 77 76
    

    输出样例:

    77 76 75 71
    

    2、实验代码:

    #include<stdio.h>
    void bubble (int a[],int n);
    int main(void)
    {
    	int n,k,b=0,i=0;
    	int a[10];
    	scanf("%d",&n);
    	for(i=0;i<n;i++){
    		scanf("%d",&a[i]);
    	}
    	bubble (a,n);
    	for(k=0;k<n;k++){
    		if(k<=n-2){
    			printf("%d ",a[k]);
    		}
    		else{
    			printf("%d",a[k]);
    		}
    	}
    	return 0;
    }
    void bubble (int a[],int n)
    {
    	int i,k,b;
    	for(k=1;k<n;k++){
    		for(i=0;i<n-k;i++){
    			if(a[i]<a[i+1]){
    		        b=a[i];a[i]=a[i+1];a[i+1]=b;
    		    }
    		}
    	}
    }
    

    3、流程图:

    4、调试过程遇到的问题:

    问题一:格式错误
    解决办法:仔细查找结果发现最后多了个空格。

    5、运行结果截图:

    学习进度条

    周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较困惑的问题
    3/11~3/16 10小时 46行 可以同时利用一维数组和二维数组来解题,以及二维数组的使用。 二维数组的二组循环比较迷惑
    3/18~3/22 8小时 110 行 冒泡排序和选择排序有相似之处,冒泡找最大值或找最小值是重复比较的,而选择一步到位。 冒泡排序按书上哪种方法把最后一个if判断条件改成小于为什么不能按大到小的顺序输出

    学习感悟

    感觉那个冒泡和选择排序有相似之处,这两个题还不太难,但那个找鞍点就有点难度,最主要的是满足条件的判断条件是什么。

  • 相关阅读:
    条件运算符
    类型
    c#
    打印菱形
    关于隐藏控制器的导航条的问题
    怎么去掉Xcode工程中的某种类型的警告 Implicit conversion loses integer precision: 'NSInteger' (aka 'long') to 'int32
    如何在导航条的button点击变换时,切换对应的控制器
    如何只选择一个
    重写TabBar遇到的按钮不显示的问题
    ASI和AFN的区别
  • 原文地址:https://www.cnblogs.com/xht8657/p/10577367.html
Copyright © 2011-2022 走看看