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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    4
    5 1 7 6

    输出样例:

    7 6 5 1

    代码

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

    遇到的问题

    循环条件错误

    错误截图

    解决方法

    将第二个循环的条件变更一下

    运行截图

    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

    代码

    
    #include<stdio.h>
    int main()
    
    {
      int n,i,j,l,k=0,index=0,judge=1;
      scanf("%d",&n);
      int a[n][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++)
          {
            index=i;
            for(l=0;l<n;l++){
              if(a[i][k]<=a[i][l]){
                k=l;
                }
                }
                for(j=0;j<n;j++){
                  if(a[index][k]>a[j][k]){
                    index=j;
                    break;
                    }
                    }
                    if(i==index){
                      judge=0;
                      break;
                      }
                      }
                      if(judge==0)
                      printf("%d %d",i,k);
                      else 
                      printf("NONE");
                      }
                      return 0;
      
    }
    
    
    

    遇到的问题

    判断条件错误

    解决方法

    将if(judge1)改为if(judge0)

    运行截图

    耗时:4小时
    心得:题目有点难度,第二题已经超出了我的能力范围,要多看书,需要自学

  • 相关阅读:
    java一个简单的线程池小例子
    java通过反射复制实体类
    java通过反射获取Object的属性
    java时间对比
    软件工程基础最后第一次作业 总结
    C++语言程序化设计——第五次作业
    软件工程基础——第四次作业
    C++语言程序化设计——第四次作业
    软件工程基础第三次作业——原型设计
    C++语言程序化设计——第三次作业
  • 原文地址:https://www.cnblogs.com/xgblz/p/10578619.html
Copyright © 2011-2022 走看看