第4周编程总结

该博客围绕C语言编程展开,包含选择法排序、找鞍点、冒泡排序等实验。介绍了各实验的输入输出格式、实验思路及流程图,还分享了遇到的问题及解决方法,如scanf格式问题、代码符号缺失等,最后提及学习进度和感悟。
这个作业属于哪个课程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; 

}
···
错误截图

1581833-20190322164921073-1652938151.png

正确截图

1581833-20190322165013546-886436398.png

实验思路

定义数组和后面所要用到的变量,输入数组元素,开始排序 ,把k的值赋给index ,k初始值为0,比较它的后面一项a[i]是否大于a[k] ,寻找最大值所在下标 ,是就后面的下标给前面,较大元素的值给t,前面一项的较小值给后面一项 ,把后面较大的值给前面一项元素a[k],使输出的时候前面和后面都没有空格
流程图
1581833-20190322171946165-1580307081.png
遇到的问题
一开始感觉很奇怪没哪里出问题,但是它要我输入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;
    
}

流程图

1581833-20190322190428386-227655621.png

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

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

改正
break;} 加上}
正确截图
1581833-20190322190841689-1094721076.png
冒泡排序

``` #include <stdio.h>
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 定义,就好了
正确截图
1581833-20190322211531103-867085760.png

实验思路

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

流程图
1581833-20190322213155224-945860562.png

学习进度条
1581833-20190322225505544-966863485.png

学习感悟

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

转载于:https://www.cnblogs.com/I-FEAR-ONLY-TIME/p/10581887.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值