• 第4周编程总结


    这个作业属于哪个课程 C语言程序设计Ⅱ
    这个作业要求在哪里 解决一些数组的简单排序问题
    我在这个课程的目标是 运用一些方法来数组排序,运用数组;二维数组
    这个作业在哪个具体方面帮助我实现目标 简单了解选择排序,和冒泡排序
    参考文献 C语言程序设计(第3版第7章
    选择法排序 (20 分)
    本题要求将给定的n个整数从大到小排序后输出。
    输入格式:
    输入第一行给出一个不超过10的正整数n。第二行给出n个整数,其间以空格分隔。
    输出格式:
    在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。
    输入样例:
    4
    5 1 7 6
    输出样例:
    7 6 5 1
    ··· #include <stdio.h>
    int main(void)
    {
    int a[10];
    int i,n,index,k,t;
    
    scanf("%d",&n);
    for(i=0;i<n;i++)
    scanf("%d",&a[i]);
    for(k=0;k<n-1;k++)
    {
    	index = k; 
    	for(i=k+1;i<n;i++) 
    	if(a[i]>a[index]) index=i; 
    	t=a[index];
    	a[index]=a[k];
    	a[k]=t; 
    }	
    printf("%d",a[0]);
    for(i=1;i<n;i++)
    printf(" %d",a[i]);
    return 0; 
    

    }
    ···
    错误截图

    正确截图

    实验思路

    定义数组和后面所要用到的变量,输入数组元素,开始排序 ,把k的值赋给index ,k初始值为0,比较它的后面一项a[i]是否大于a[k] ,寻找最大值所在下标 ,是就后面的下标给前面,较大元素的值给t,前面一项的较小值给后面一项 ,把后面较大的值给前面一项元素a[k],使输出的时候前面和后面都没有空格
    流程图

    遇到的问题
    一开始感觉很奇怪没哪里出问题,但是它要我输入5个元素才能把程序运行完,否则进行不了,发现把书上的例题稍加修改就可以,然后还是不对,后面发现是scanf("%d",&a[i])多加了一个空格,然后我查了一下他的原因,发现空格后面没有输入其他空格以外的字符,scanf会一直跳过空格然后等待输入,直到输入非空格字符后scanf才会返回 ,然后把空格删去,结果正确

    找鞍点

    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 a[6][6];
    	int n,i,j;
    	scanf("%d",&n);
    	for(i=0;i<n;i++)
    		for(j=0;j<n;j++){
    			scanf("%d",&a[i][j]);
    		}
    	
    	int x=0,y=0,z=0,flag=1;
    	if(n==1)
    	printf("0 0");
    	else
    	{
    		for(i=0;i<n;i++)
    		{
    			y=i;
    			for(z=0;z<n;z++)
    			{
    			if(a[i][x]<=a[i][z])
    			  {
    			x=z;
    			  }
    			} 
    		for(j=0;j<n;j++)
    		{
    		if(a[y][x]>a[j][x]) 
    		  {
    		y=j;
    		break;
    		  } 
    		}
    		if(i==y)
    		{
    		flag=0;
    		break;
    		}
    		if(flag==0)
    		printf("%d %d",i,x);
    		else printf("NONE");	
    	}
    	return 0;
    	
    }
    

    流程图

    实验思路
    找出每一行最大的元素和下标,再从该列找出小的元素

    遇到错误
    [Error] expected '}' at end of input,不停修改,还是出了问题,然后修改,少打了一个}

    改正
    break;} 加上}
    正确截图

    冒泡排序

    void bubble (int a[],int n);
    int main (void)
    {
    	int n,a[10];
    	int i;
    	
    	scanf("%d",&n);
    	for(i=0;i<n;i++)
    	scanf("%d",&a[i]);
    	bubble (a,n);
    	printf("%d",a[0]);
    	for(i=1;i<n;i++)
    	printf(" %d",a[i]);
    	
    	return 0;
     } 
     void bubble (int a[],int n)
     {
     	int i,j,t; 
     	for(i=1;i<n;i++)
     	for(j=0;j<n-i;j++)
     	if(a[j]<a[j+1])
     	{
     		t=a[j];
     		a[j]=a[j+1];a[j+1]=t; 
    	 }
     }
    

    遇到错误
    忘记在定义函数中间定义 i j t
    uploading-image-359240.png
    解决方法
    把i j t 定义,就好了
    正确截图

    实验思路

    定义一个函数bubble来排序,把较大的值放到数组前面

    流程图

    学习进度条

    学习感悟

    学习要多时间,还要去复习以前的和预习以后的

  • 相关阅读:
    洛谷 P1244 青蛙过河
    洛谷 P1004 方格取数
    洛谷 CF894A QAQ
    【题解】洛谷 P5506 封锁
    洛谷 P3884 [JLOI2009]二叉树问题
    Bzoj4894 天赋
    Bzoj4893 项链分赃
    Bzoj3583 杰杰的女性朋友
    POJ3233 Matrix Power Series
    UOJ#204 【APIO2016】Boat
  • 原文地址:https://www.cnblogs.com/I-FEAR-ONLY-TIME/p/10581887.html
Copyright © 2020-2023  润新知