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 我想在一个软件里添加一个优惠弹窗,应该怎么写代码
  • ¥15 fluent的在模拟压强时使用希望得到一些建议
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流