第四周作业

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判断条件改成小于为什么不能按大到小的顺序输出

学习感悟

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

posted @ 2019-03-22 11:53  xht8657  阅读(172)  评论(2编辑  收藏  举报