| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1064 人关注过本帖
标题:啊。。。抓狂,程序。。。
只看楼主 加入收藏
jeff19902
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-10-16
结帖率:0
收藏
已结贴  问题点数:20 回复次数:16 
啊。。。抓狂,程序。。。
Description:
有一些01字串,将其按1的个数的多少的顺序进行输出。

Sample Input:
10011111
00001101
1010101
1
0
1100
Sample Output:
0
1
1100
00001101
1010101
10011111

自己给自己出了个烦人的题。。。郁闷的。脑袋打结了。。好心的人帮我看看。。啊呜。。
搜索更多相关主题的帖子: 抓狂 
2009-10-16 15:19
UserYuH
Rank: 12Rank: 12Rank: 12
来 自:毅华
等 级:火箭侠
威 望:8
帖 子:720
专家分:3300
注 册:2009-8-10
收藏
得分:3 
用链表来做。每个结点保存字串和1出现的次数,再对1出现的次数排序链表,再输出就是你要的结果
struct strs   
{   
char str[20];   保存0和1字串   
int n;         记下字串中1出现的次数   
struct strs *next;        
};   

努力—前进—变老—退休—入土
2009-10-16 15:39
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
收藏
得分:3 
定义一个二维数组用于存放0 1 定以一个一维数组用于存放二维数组中每行中的1的个数,比较一维数组的数的大小用来调用输出二维数组中1的个数最小的行,次之。。。。到最后。。一个想法。

离恨恰如春草,更行更远还生。
2009-10-16 15:40
jeff19902
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-10-16
收藏
得分:0 
回复 2楼 UserYuH
啊呜。。我还是比较初级的阶段呢,链表才刚刚接触。。能不能用简单点的?
2009-10-16 15:46
jeff19902
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-10-16
收藏
得分:0 
回复 3楼 玩出来的代码
可是这个输入的数据不知道有多少行的呀。。怎么结束输入呢?
2009-10-16 15:49
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
收藏
得分:0 
怎么结束输入?什么意思?不知道多少行用数组确实不如用链表好,若这样可以定义成一个足够大的数组,就是浪费空间了。。

离恨恰如春草,更行更远还生。
2009-10-16 17:55
流星雨
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:JAVA风暴
等 级:版主
威 望:43
帖 子:1854
专家分:1868
注 册:2004-5-30
收藏
得分:3 
这个简单啊,你创建一个字符串数组,存储你压迫排序的数据。再建一个int数组的长度就是是你,输入的数据的组数,
然后再循环你输入的那些字符串,设你这里也是用数组定义的,你用一个循环,把每个对应的字符串的1统计出来,存储在
INT数组里。再根据INT数组的数据对字符串数组进行排序。不过你熟悉指针的话,建一个指针数组,直接对下标进行排序更好。

感谢你们带我找到星空下美丽神话,无论经历多少苦痛也不放弃的梦;插上希望翅膀乘风我和你们飞翔,飞过海天尽头携手把梦想实现.....
2009-10-16 18:08
Quavarion
Rank: 2
等 级:论坛游民
帖 子:60
专家分:28
注 册:2009-10-9
收藏
得分:3 
#include<stdio.h>
void main()
{
  int a[5][5],sum[5]={0};
   int i,j,k,m,t,h;
    for(i=0;i<5;i++)
     {
        printf("Please input the  code:\n");
        for(j=0;j<5;j++)
         {
          scanf("%d",&a[i][j]);
           if(a[i][j]==1) sum[i]++;
          }
      }
 
 
 
     printf("The result:\n");
      for(h=0;h<5;h++)
        printf("%d\n",sum[h]);
 
      getch();
}
 
这个程序还有待改进,希望高人指点.
2009-10-16 19:30
wangdezi
Rank: 1
等 级:新手上路
帖 子:13
专家分:9
注 册:2009-10-16
收藏
得分:3 
楼上的是高手啊!!!!!!
2009-10-16 21:40
jeff19902
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2009-10-16
收藏
得分:0 
回复 7楼 流星雨
大哥。。。结果不是叫你把和求出来。。。
2009-10-16 21:45
快速回复:啊。。。抓狂,程序。。。
数据加载中...
 
   



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

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