| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 324 人关注过本帖
标题:求助,给位帮我改一下好吗,我不知道是哪里错了
只看楼主 加入收藏
thlgood
Rank: 5Rank: 5
等 级:职业侠客
帖 子:281
专家分:381
注 册:2010-9-24
结帖率:91.43%
收藏
已结贴  问题点数:20 回复次数:5 
求助,给位帮我改一下好吗,我不知道是哪里错了
程序代码:
/*Date:2011-4-2,多维数组和指针的传值*/
#include <stdio.h>
#include <stdlib.h>

#define WIDE 20  //数组矩阵的宽度
#define HIGH 20  //数组矩阵的高度

void sort(int (*p)[WIDE]);  //排序
void intswap(int a, int b); //变量值交换

int main()
{
    int x[HIGH][WIDE];
    int i;

    srand(time(NULL));
    for(i=0; i<WIDE*HIGH; i++)
    {
        *(&x[0][0]+i)=rand();
    }
    for(i=0; i<WIDE*HIGH; i++)
    {
        printf("%d\t", *(&x[0][0]+i));
    }

    printf("\n\n\n随机数生成完毕!");
    system("pause");
    sort(x);
    return 0;
}

/*定义排序函数*/
void sort(int (*p)[20])
{
    int i, j;
    for(i=0; i<WIDE*HIGH-2; i++)
    {
        for(j=i; j<WIDE*HIGH-2; j++)
        {
            if( *(&p[0][0]+i) < *(&p[0][0]+j) )
            intswap( *(&p[0][0]+i), *(&p[0][0]+j) );
        }
    }
    for(i=0; i<WIDE*HIGH; i++)
    {
        printf("%d\t", *(&p[0][0]+i));
    }
}

/*定义交换函数*/
void intswap(int a, int b)
{
    a=a+b;
    b=a-b;
    a=a-b;
}

给程序是利用函数生成一个伪随机数,然后将这组伪随机数赋给二维数组,再排序,可是,不知道是什么原因,该程序不能排序
2011-04-02 22:40
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:2 
1
头文件少了time.h
2
交换函数形参必须指明合适类型的指针
3
可以先将二维数组展开成一维的, 排序完以后在转成二维的。

4,初学者者,有不对的地方忽视。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-04-02 22:52
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:6 
二维数组排序算法代码,仅供参考。
程序代码:
        int i,j,l,k,temp;
        for(i=0;i<N;i++) {
                for(j=0;j<N;j++) {
                        for(l=i;l<N;l++) {
                                for(k=j;k<N;k++) {
                                        if(a[i][j]>a[l][k]) {
                                                temp=a[i][j];
                                                a[i][j]=a[l][k];
                                                a[l][k]=temp;
                                        }
                                }
                        }
                }
        }

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-04-02 22:55
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:10 
程序代码:
/*Date:2011-4-2,多维数组和指针的传值*/
#include <stdio.h>
#include <stdlib.h>

#define WIDE 20  //数组矩阵的宽度
#define HIGH 20  //数组矩阵的高度

void sort(int (*p)[WIDE]);  //排序
void intswap(int *a, int *b); //变量值交换

int main()
{
    int x[HIGH][WIDE];
    int i;

    srand(time(NULL));
    for(i=0; i<WIDE*HIGH; i++)
    {
        *(&x[0][0]+i)=rand();
    }
    for(i=0; i<WIDE*HIGH; i++)
    {
        printf("%d\t", *(&x[0][0]+i));
    }

    printf("\n\n\n随机数生成完毕!");
    system("pause");
    sort(x);
    return 0;
}

/*定义排序函数*/
void sort(int (*p)[20])
{
    int i, j;
    for(i=0; i<WIDE*HIGH; i++)
    {
        for(j=i; j<WIDE*HIGH; j++)
        {
            if( *(&p[0][0]+i) < *(&p[0][0]+j) )
            intswap( &p[0][0]+i, &p[0][0]+j );
        }
    }
    for(i=0; i<WIDE*HIGH; i++)
    {
        printf("%d\t", *(&p[0][0]+i));
    }
}

/*定义交换函数*/
void intswap(int *a, int *b) //用指针交换,形参不能传给实参。
{
    *a = (*a) + (*b) ;
    *b = (*a) - (*b) ;
    *a = (*a) - (*b) ;
}
冒泡排序效率低了点,可以考虑别的排序方法。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-04-02 23:04
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:2 
楼主犯了一个比较低级的错误,这是能编出这种程序的人不该犯的。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-04-02 23:05
lucky563591
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:765
专家分:2103
注 册:2009-11-18
收藏
得分:0 
感觉你的system pause不对
2011-04-03 07:44
快速回复:求助,给位帮我改一下好吗,我不知道是哪里错了
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019642 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved