| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 278 人关注过本帖
标题:求高手指点!!!!!!谢啦!!!!
只看楼主 加入收藏
hugh浪迹
Rank: 2
等 级:论坛游民
帖 子:30
专家分:39
注 册:2011-6-17
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
求高手指点!!!!!!谢啦!!!!
我写了一个小程序,用来实现将一个二维字符数组中的每一个字符串的字符按升序重新排列。要求能初始化输入字符串数组并输出。主函数只能调用一次子函数。写好以后,编译和链接都没有问题,但是运行以后发现只能实现对第一个字符串的排序,其他字符串都变成了乱码。。。这是什么原因啊?求指点!!
程序代码:
#include<stdio.h>

 #include<stdlib.h>

 #define N 2 

 #define M 51

 int main()

 {
     void range(char b[][M]);
     char a[N][M];
     int i;
     printf("请输入%d个字符串,每个字符串不超过%d个字符(每个字符串以回车键结束):\n",N,M-1);
     for(i=0;i<N;i++)
         gets(a[i]);
     printf("您输入的字符串为:\n");
     for(i=0;i<N;i++)
     {
         puts(a[i]);
     }
     printf("对每个字符串按升序排列:\n");
     range(a);
     printf("排序后的字符串为:\n");
     for(i=0;i<N;i++)
     {
         puts(a[i]);
         printf("\n");
     }
     return(0);

 }

 void range(char b[][M])

 {
     int m,n,p,sum=0;
     char c;
     for(n=0;n<N;n++)
     {
         for(m=0;b[n][m]>0;m++)
             sum+=1;
         for(p=0;p<sum-1;p++)
         {
             for(m=0;m<sum-1-p;m++)
                 if(b[n][m]>b[n][m+1])
                 {
                     c=b[n][m];
                     b[n][m]=b[n][m+1];
                     b[n][m+1]=c;
                 }
         }
     }

 }

搜索更多相关主题的帖子: 字符串 color 
2011-06-22 19:40
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:10 
for(sum = 0, m=0;b[n][m]>0;m++)    // 要给 sum 清零。不然从第二个字符串开始,求得的字符串长度会超过字符串的实际长度
    sum+=1;
2011-06-22 20:25
hugh浪迹
Rank: 2
等 级:论坛游民
帖 子:30
专家分:39
注 册:2011-6-17
收藏
得分:0 
回复 2楼 voidx
原来是这个样子。。嘿,谢啦谢啦
2011-06-23 13:07
快速回复:求高手指点!!!!!!谢啦!!!!
数据加载中...
 
   



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

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