| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1051 人关注过本帖
标题:关于筛选相似数的问题?请进
只看楼主 加入收藏
zwh9437
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2016-4-11
结帖率:0
收藏
已结贴  问题点数:20 回复次数:5 
关于筛选相似数的问题?请进
是这样的
比如有这几个数
3,4,78,5,18,19,20,77,80,79
我想要设定如果两个数之间相差5就认定为是一个范围的数,并且把这个范围的数求和平均值,最后输出出来。
比如这个例子中。
3,4,5是一组,18,19,20是一组。77,78,79,80是一组.
我希望最后可以自动筛选后输出出   4,20,78.5这样的结果
请问应该如何编写C程序呢??感谢各位了!!

[此贴子已经被作者于2016-4-11 17:44编辑过]

2016-04-11 17:35
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:5 
听不懂,比如1 2 3 4 5 6 7,你怎么分组?
2016-04-11 18:04
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:5 
先排序,然后按一定范围从0开始取值,否则没有基准点没法划分。
比如1 2 3 4 5 6 7,相差2以内为一组,那么3你是分在1那边还是5那边?
2016-04-11 18:10
zhulei1978
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:53
帖 子:1351
专家分:1200
注 册:2006-12-17
收藏
得分:5 
以下是引用grmmylbs在2016-4-11 18:10:35的发言:

先排序,然后按一定范围从0开始取值,否则没有基准点没法划分。
比如1 2 3 4 5 6 7,相差2以内为一组,那么3你是分在1那边还是5那边?



他那个题目里应该有避免这种情况的

其实我就是改变社会风气,提高少女素质,刺激电影市道,提高年轻人内涵,玉树临风,风度翩翩的整蛊专家,我名叫古晶,英文名叫JingKoo!
2016-04-11 18:23
zwh9437
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2016-4-11
收藏
得分:0 
因为是工程实际问题,所以避免了出现1,2,3,4,5,6,7这种情况的。。。不过,还是没听懂先排序从0开始的意思?。。。
2016-04-11 18:50
qq1023569223
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:湖南科技大学
等 级:贵宾
威 望:26
帖 子:2753
专家分:13404
注 册:2010-12-22
收藏
得分:5 
程序代码:
#include <stdio.h>
#define N 10  //处理的数字个数
#define M 5   //同组数字的最大差值

//初始化数组元素全为0
void clean(int a[])
{
    int i;
    for(i=0;i<N;i++)
    {
        a[i]=0;
    }
}

//从小到大排序
void sort(int a[])
{
    int i,j,tmp;

    for(i=0;i<N-1;i++)
    {
        for(j=i+1;j<N;j++)
        {
            if(a[i]>a[j])
            {
                tmp=a[i];
                a[i]=a[j];
                a[j]=tmp;
            }
        }
    }
}

//输出同级数字及平均值
void display(int a[])
{
    int i=0,sum=0;

    for(;a[i]!=0;i++)
    {
        if(i==N)  break;
        printf("%d ",a[i]);
        sum+=a[i];
    }

    printf("aver=%.3f\n",(float)sum/i);
}

int main()
{
    int nums[N]={3,4,78,5,18,19,20,77,80,79};
    int a[N];  //存储同组数字

    sort(nums);
    clean(a);

    int i,j=0;
    for(i=0;i<N;i++)
    {
        if(j==0)  //同组开头数字
        {
            a[j]=nums[i];
            j++;
            continue;
        }

        if((nums[i]-nums[i-1])<=M)
        {
            a[j]=nums[i];
            j++;

            if(i==N-1)  display(a);  //特殊情况,输出最后一组
        }
        else  //输出同组数据
        {
            i--;  //退一位
            j=0;
            display(a);
            clean(a);
        }
    }

    return 0;
}

   唯实惟新 至诚致志
2016-04-11 19:06
快速回复:关于筛选相似数的问题?请进
数据加载中...
 
   



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

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