weixin_43907392 2018-12-16 06:51 采纳率: 75%
浏览 10979
已采纳

编写一个void sort(int *x,int n)函数,实现用“冒泡法”将x数组中的n个数据从小到大排序

编写一个void sort(int x,int n)函数,实现用“冒泡法”将x数组中的n个数据从小到大排序。主函数中定义二维数组int a[3][5],数组元素从键盘输入,调用sort函数将第2行数从小到大排序,在主函数中输出a数组
#include
void sort(int *x,int n)
{
int i,j,temp,a[3][5];
x=a[0];
for(i=0;i<4;i++)
for(j=0;j<4-i;j++)
if(
(x+4*n+j)>(x+4*n+j+1))
{
temp=
(x+4*n+j+1);
(x+4*n+j+1)=(x+4*n+j);
*(x+4*n+j)=temp;
}
}
main()
{
int a[3][5],i,j;
for(i=0;i<3;i++)
for(j=0;j<5;j++)
scanf("%6d",&a[i][j]);
sort(a,1);
for(i=0;i<3;i++)
for(j=0;j<5;j++)
printf("%5d",a[i][j]);
}

我这个有错误,看不出来,则么改

  • 写回答

2条回答 默认 最新

  • threenewbee 2018-12-16 07:03
    关注
    #include "stdio.h"
    
    void sort(int *x,int n)
    {
        int i,j,temp;
        for(i=0;i<4;i++)
            for(j=0;j<4-i;j++)
                if(*(x+n*5+j)>*(x+n*5+j+1))
                {
                    temp=*(x+n*5+j+1);
                    *(x+n*5+j+1)=*(x+n*5+j);
                    *(x+n*5+j)=temp;
                }
    }
    int main()
    {
        int a[3][5],i,j;
        for(i=0;i<3;i++)
            for(j=0;j<5;j++)
                scanf("%6d",&a[i][j]);
        sort(&a[0][0],1);
        for(i=0;i<3;i++)
        {
            for(j=0;j<5;j++)
                printf("%5d",a[i][j]);
            printf("\n");
        }
    }
    

    图片说明

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 adb连接不到手机是怎么回事?
  • ¥15 vs2022无法联网
  • ¥15 TCP的客户端和服务器的互联
  • ¥15 VB.NET操作免驱摄像头
  • ¥15 笔记本上移动热点开关状态查询
  • ¥85 类鸟群Boids——仿真鸟群避障的相关问题
  • ¥15 CFEDEM自带算例错误,如何解决?
  • ¥15 有没有会使用flac3d软件的家人
  • ¥20 360摄像头无法解绑使用,请教解绑当前账号绑定问题,
  • ¥15 docker实践项目