| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 630 人关注过本帖
标题:POJ 1007
只看楼主 加入收藏
wangyun1993
Rank: 1
来 自:NIT
等 级:新手上路
帖 子:2
专家分:0
注 册:2011-12-14
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:5 
POJ 1007
程序代码:
#include<stdio.h>
#include<string.h>
int main()
{
    char a[101][51]={0},b[51];
    int m,n,i,j;
    scanf("%d%d",&m,&n);
    for(i=0;i<n;i++)
    {
        for(j=0;j<m;j++)
            scanf("%c",&a[i][j]);
        getchar();
    }
    for(i=0;i<n;i++)    
        for(j=0;j<m;j++)
            if(a[i][j]>a[i][j+1])
                a[100][i]++;
    for(i=0;i<n;i++)
        for(j=0;j<n-i;j++)
            if(a[100][i]>a[100][i+1])
            {
                strcpy(b,a[i]);
                strcpy(a[i],a[i+1]);
                strcpy(a[i+1],b);
            }
    for(i=0;i<n;i++)
        printf("%s\n",a[i][m]);
    return 0;
}

为什么输出都是NULL,不接
题目:http://

[ 本帖最后由 wangyun1993 于 2011-12-31 12:52 编辑 ]
搜索更多相关主题的帖子: color 
2011-12-31 12:44
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
程序代码:
#include <stdio.h>
#include <stdlib.h>
char data[1000][500] = {0};
struct Node
{
    int sum;
    int num;
};
Node mem[1000] = {0};
int cmp(const void *pa,const void *pb)
{
    return ((Node *)pa)->sum - ((Node *)pb)->sum;
}
int main()
{
    int i,j,k;
    int n,m;
    scanf("%d %d",&n,&m);
    for(i = 0;i<m;i++)
    {
        scanf("%s",data[i]);
        int sum = 0;
        for(j = 0;j<n;j++)
        {
            for(k = j+1;k<n;k++)
                if(data[i][k]<data[i][j])
                    sum++;
        }
        mem[i].sum = sum;
        mem[i].num = i;
    }
    qsort(mem,m,8,cmp);
    for(i = 0;i<m;i++)
        printf("%s\n",data[mem[i].num]);
    return 0;
}

                                         
===========深入<----------------->浅出============
2011-12-31 19:16
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:2 
老杨没调试过代码吧?存在一些笔误。
另外还有一个问题,那就是qsort排序是不稳定的,即当两个元素相同时,其排序后不一定谁在前谁在后。
而题目要求两个串的逆序值相同时,按原顺序输出。该怎么解决呢?

重剑无锋,大巧不工
2011-12-31 19:30
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
回复 3楼 beyondyf
感谢杨大哥的提醒  我貌似没考虑原顺序输出  很长时间以前提交AC的代码  我去想想

                                         
===========深入<----------------->浅出============
2011-12-31 19:56
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:18 
程序代码:
int cmp(const void *pa,const void *pb)
{
    if(((Node *)pa)->sum != ((Node *)pb)->sum)
        return ((Node *)pa)->sum - ((Node *)pb)->sum;
    else
        return ((Node *)pa)->num - ((Node *)pb)->num;
}


这样貌似就解决了吧  也能AC

                                         
===========深入<----------------->浅出============
2011-12-31 20:04
wangyun1993
Rank: 1
来 自:NIT
等 级:新手上路
帖 子:2
专家分:0
注 册:2011-12-14
收藏
得分:0 
回复 5楼 laoyang103
不会 看不懂int imp里面的const不会 看不懂int imp里面的const

[ 本帖最后由 wangyun1993 于 2011-12-31 20:25 编辑 ]
2011-12-31 20:24
快速回复:POJ 1007
数据加载中...
 
   



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

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