鱼C论坛

 找回密码
 立即注册
查看: 1829|回复: 7

[已解决]大佬帮忙看一下 C的相同字符删除与计数

[复制链接]
发表于 2019-2-25 20:50:21 | 显示全部楼层 |阅读模式
10鱼币
#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<ctype.h>
#include<string.h>
#define N 50
int main()
{
    int b[N]={0,0,1,2,2,3,4,4,4,4,5,5,5,5,6,7,8,8,9,9};
    int times[N]={0};
    int i,j,k=0,count,n=N;
    for(i=0; i<n; i++)
    {
        count=1;
        for(j=i; j<n; j++)
        {
            if(b[j]==b[j+1])
            count++;
            else
            {
                times[k++]=count;
                i=j;
                break;
            }
        }    
        if(b[n-1]!=b[n-2] && i==n-1)
            times[k++]=count;
    }    
    j=1;
    for(i=1; i<n; i++)
    {
        if(b[j-1]!=b[i])
        b[j++]=b[i];
    }
    for(i=0; i<k; i++)
    printf("%d ³öÏÖ %d´Î\n",b[i],times[i]);
}
最佳答案
2019-2-25 20:50:22
本帖最后由 jackz007 于 2019-2-26 11:00 编辑
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

#define N 50

int main()
{
        int b[N]={0 , 0 , 1 , 2 , 2 , 3 , 4 , 4 , 4 , 4 , 5 , 5 , 5 , 5 , 6 , 7 , 8 , 8 , 9 , 9} ;
        int times[N] = {0}                                                                       ;
        int i , k = 1                                                                            ;
        times[k - 1] = 1                                                                         ;
        for(i = 1 ; i < N ; i ++) {
                if (b[i] == b[k - 1]) times[k - 1] ++                                            ;  // 目标元素与当前备案比较,如果相同则计数值增 1
                else {                                                                                      
                        if (b[i] < b[k - 1]) break                                               ;  // 如果目标元素比当前备案值小则结束循环
                        else {
                                k ++                                                             ;  // 目标元素与备案元素不同,备案索引 k 增 1
                                b[k - 1] = b[i]                                                  ;  // 为新元素建立备案
                                times[k - 1] = 1                                                 ;  // 把新元素出现的次数初始化为 1
                        }
                }
        }
        for(i = 0 ; i < k ; i ++) printf("%d 出现 %d次\n" , b[i] , times[i])                     ;
}

    运行情况:
G:\[2019]\00.00.Exercise\C\Count>x
0 出现 2次
1 出现 1次
2 出现 2次
3 出现 1次
4 出现 4次
5 出现 4次
6 出现 1次
7 出现 1次
8 出现 2次
9 出现 2次

G:\[2019]\00.00.Exercise\C\Count>
批注 2019-02-25 204909.jpg

最佳答案

查看完整内容

运行情况: G:\[2019]\00.00.Exercise\C\Count>x 0 出现 2次 1 出现 1次 2 出现 2次 3 出现 1次 4 出现 4次 5 出现 4次 6 出现 1次 7 出现 1次 8 出现 2次 9 出现 2次 G:\[2019]\00.00.Exercise\C\Count>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-25 20:50:22 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2019-2-26 11:00 编辑
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

#define N 50

int main()
{
        int b[N]={0 , 0 , 1 , 2 , 2 , 3 , 4 , 4 , 4 , 4 , 5 , 5 , 5 , 5 , 6 , 7 , 8 , 8 , 9 , 9} ;
        int times[N] = {0}                                                                       ;
        int i , k = 1                                                                            ;
        times[k - 1] = 1                                                                         ;
        for(i = 1 ; i < N ; i ++) {
                if (b[i] == b[k - 1]) times[k - 1] ++                                            ;  // 目标元素与当前备案比较,如果相同则计数值增 1
                else {                                                                                      
                        if (b[i] < b[k - 1]) break                                               ;  // 如果目标元素比当前备案值小则结束循环
                        else {
                                k ++                                                             ;  // 目标元素与备案元素不同,备案索引 k 增 1
                                b[k - 1] = b[i]                                                  ;  // 为新元素建立备案
                                times[k - 1] = 1                                                 ;  // 把新元素出现的次数初始化为 1
                        }
                }
        }
        for(i = 0 ; i < k ; i ++) printf("%d 出现 %d次\n" , b[i] , times[i])                     ;
}

    运行情况:
G:\[2019]\00.00.Exercise\C\Count>x
0 出现 2次
1 出现 1次
2 出现 2次
3 出现 1次
4 出现 4次
5 出现 4次
6 出现 1次
7 出现 1次
8 出现 2次
9 出现 2次

G:\[2019]\00.00.Exercise\C\Count>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-25 22:56:14 | 显示全部楼层
这个输出没有问题啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-25 22:58:31 | 显示全部楼层
int b[N]={0,0,1,2,2,3,4,4,4,4,5,5,5,5,6,7,8,8,9,9};
你的数组前20个为定义的数字,其余30个确实为0啊,没毛病啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-26 12:18:50 | 显示全部楼层
910201513 发表于 2019-2-25 22:58
int b[N]={0,0,1,2,2,3,4,4,4,4,5,5,5,5,6,7,8,8,9,9};
你的数组前20个为定义的数字,其余30个确实为0啊, ...

没注意
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-26 12:22:10 | 显示全部楼层
jackz007 发表于 2019-2-25 20:50
运行情况:
G:\[2019]\00.00.Exercise\C\Count>x
0 出现 2次

如果数字不是有序的话就不可以这么做了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-26 12:31:27 | 显示全部楼层
我是个汉子 发表于 2019-2-26 12:22
如果数字不是有序的话就不可以这么做了

      确实如此,代码设计与楼主的实际问题相呼应。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-26 12:35:29 | 显示全部楼层
jackz007 发表于 2019-2-26 12:31
确实如此,代码设计与楼主的实际问题相呼应。

代码够用了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-17 06:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表