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

编写一个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条)

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码