2019年春季第四周 编程总结

一、基础作业

第一题:

(1、题目 5-1:
输入一个正整数 n (1≤n≤10)和n 阶方阵a的元素,如果方阵a中的所有元素都沿主对角线对称,输出“Yes”, 否则,输出“No”。主对角线为从矩阵的左上角至右下角的连线,方阵a中的所有元素都沿主对角线对称指对所有i, k,a[i][k]和a[k][i]相等。输入输出示例如下:

输入:
3
1 2 3
4 5 6
7 8 9
输出:
No

(2、程序代码:

#include <stdio.h>
int main (void)
{
int found, i, k, n;
int a[10][10];

scanf ("%d", &n);
for (i = 0; i < n; i++)	
	for (k = 0; k < n; k++)
		scanf("%d", &a[i][k]);

	found = 1;
	for (i = 0; i < n; i++){	
	for (k = 0; k < i; k++){
	if (a[i][k]!=a[k][i]) {	
			  found=0;
			  break;
			}
	}
	if (found==0){
			  break;
			}
	}

	if (found != 0){
		     printf("Yes\n");
	}  
	else{
		  	printf("No\n");
}  

	return 0;
}

(3、设计填写思路:
根据题意,要使程序能正确判断n阶方阵是否对称,通过变量found=1假设为对称,根据矩阵型二维数组特性再在空白处填写 a[i][k] != a[k][i] 进行判断;
用if判断若出现对应数值不相等,即不对称,则令found=0;进而以两个break跳出两层for循环;
结合found!=0输出yes,故而另一空白处应填写found==0‘’

(4、程序运行结果的截图或者效果录像。
错误截图:

问题:逻辑错误,导致不合题意。
解决办法:对程序进行调试,发现if判断语句不符题目要求,
                  进行修改,将a[i][k]!=a[k][i]改为found==0。

正确截图:

第二题:
(1:题目:7-2 选择法排序

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

输入格式:

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

输出格式:

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

输入样例:
4
5 1 7 6
输出样例:
7 6 5 1

(2、程序代码:

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

(3、设计思路,流程图:

(4、程序运行结果的截图或者效果录像。
错误截图:

    问题:程序在相关软件上运行正确,但在PTA提示格式错误;设计不完善,
               根据题意《在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。》,因而出错。
    解决办法:对程序输出部分进行调整改写,思路为先行输出一个数,而后用for循环按先一空格再接一数规则输出。




    正确截图:

第三题:
(1、题目:7-1 找鞍点

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

本题要求编写程序,求一个给定的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 (void)
{
  int i, j ,n, max, x, y;
  scanf("%d",&n);
  int a[n][n];
  for(i=0;i<n;i++)
     for(j=0;j<n;j++)
      scanf("%d",&a[i][j]);

  for(i=0;i<n;i++)
   {
     max=a[i][0];
    x=0;  y=1;

     for (j=0;j<n;j++)
     if( a[i][j] >= max )
     {
      max=a[i][j];
       x=j;
      }

      for(j=0;j<n;j++)
      if( max > a[j][x] )
      {
        y=0;
        break;
      }
    if(y==1)
    {
      printf("%d %d",i,x); 
      break;
    }
  }

  if(y==0)
  printf("NONE");

  return 0;
}

(3、设计思路,流程图:

(4、程序运行结果的截图或者效果录像。
错误截图:

    问题:程序编写正确,但设计不全面,为考虑到较为特殊情况。
    解决办法:程序中在《先确定每一行中的最大值所在的列》此处应考虑极值并列的情况,
                      故应将if句处改写为 a[i][j] >= max。





    正确截图:

二、挑战作业

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

输入格式:

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

输出格式:

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

输入样例:
4 
75 71 77 76
输出样例:
77 76 75 71

2、实验代码:

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

3、设计思路,流程图:

4、程序运行结果的截图或者效果录像。

    错误截图:

    问题:程序编写正确,但设计不全面,为考虑到较为特殊情况,即若数组中存在两数相同时的排序。
    解决办法:补写程序,通过网上查找相同题目的程序代码,借鉴补写不足之处。

    正确截图:

三、对自己作业的评价:

1)、存在的问题:对二维数组的数据处理还不太顺畅。

2)、解决办法:加强练习,读写、改写、调整程序,多多益善。

3)、心得:程序设计总有不妥之处,调试不可少也是我们的好帮手。

4)、完成作业的时间消耗:4天。

5、学习进度表:

月\日~日\周 这周花的时间 代码 学到的知识点简介 目前比较迷惑的问题
3\18~22\第四周 4天 -- 冒泡排序法、选择排序法、二维数组 逻辑不太清晰
3\11~16\第三周 5天 -- 指针、二维数组 指针概念模糊

四、学习总结:

本周课堂理论课核心为二维数组的概念与运用,和通过数组与for循环处理数据的冒泡排序法、选择排序法等。

首先,冒泡排序法,以小到大排序为例,整个排序过程就好像气泡不断从水里冒出来,最大的先出来,次大的第二出来,最小的最后出来。

其次,选择排序法,是对定位比较交换法,通过比较调整数组中的位置进而从无序达到有序。

posted @ 2019-03-22 16:35  青尘忆梦  阅读(225)  评论(2编辑  收藏  举报