鱼C论坛

 找回密码
 立即注册
查看: 1201|回复: 3

[已解决]数字过滤

[复制链接]
发表于 2020-11-15 09:04:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述
给定一批整数,经每个整数中各位上为偶数的数字去掉,在顺次排列得到一个新的整数。并输出。
例如一个整数15236,转换后为153

输入:
每行一个待转换的整数,最后一个-1表示结束。

(-1不用转换)

输出:
n行,转换后的整数。

样例输入
152435
126523
5623561
-1
样例输出
1535
153
5351
提示

如果没有奇数,则输出0
最佳答案
2020-11-15 10:23:57
  1. #include<stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. int Trim(int num)
  5. {
  6.         int i = 0;
  7.         int len = 0;
  8.         char buffer[16] = {0};
  9.         sprintf(buffer,"%d",num);
  10.         len = strlen(buffer);

  11.         for(i=0 ; i<len ; )
  12.         {
  13.                 if(buffer[i]!='-' && buffer[i]%2==0)
  14.                 {
  15.                         memcpy(buffer+i,buffer+i+1,len-i-1);
  16.                         buffer[--len] = 0;
  17.                 }
  18.                 else
  19.                 {
  20.                         i++;
  21.                 }
  22.         }

  23.         return(atoi(buffer));
  24. }

  25. int main()
  26. {
  27.         int arr[10] = {0};
  28.         int count = 0;
  29.         int i = 0;
  30.        
  31.         for(count=0 ; count<10 ; count++)
  32.         {
  33.                 scanf("%d",&i);
  34.                 if(i == -1)
  35.                 {
  36.                         break;
  37.                 }
  38.                 arr[count] = i;
  39.         }

  40.         for(i=0 ; i<count ;i++)
  41.         {
  42.                 printf("%d\n",Trim(arr[i]));
  43.         }

  44.         return 0;
  45. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-15 10:23:57 | 显示全部楼层    本楼为最佳答案   
  1. #include<stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. int Trim(int num)
  5. {
  6.         int i = 0;
  7.         int len = 0;
  8.         char buffer[16] = {0};
  9.         sprintf(buffer,"%d",num);
  10.         len = strlen(buffer);

  11.         for(i=0 ; i<len ; )
  12.         {
  13.                 if(buffer[i]!='-' && buffer[i]%2==0)
  14.                 {
  15.                         memcpy(buffer+i,buffer+i+1,len-i-1);
  16.                         buffer[--len] = 0;
  17.                 }
  18.                 else
  19.                 {
  20.                         i++;
  21.                 }
  22.         }

  23.         return(atoi(buffer));
  24. }

  25. int main()
  26. {
  27.         int arr[10] = {0};
  28.         int count = 0;
  29.         int i = 0;
  30.        
  31.         for(count=0 ; count<10 ; count++)
  32.         {
  33.                 scanf("%d",&i);
  34.                 if(i == -1)
  35.                 {
  36.                         break;
  37.                 }
  38.                 arr[count] = i;
  39.         }

  40.         for(i=0 ; i<count ;i++)
  41.         {
  42.                 printf("%d\n",Trim(arr[i]));
  43.         }

  44.         return 0;
  45. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-15 10:48:02 | 显示全部楼层
本帖最后由 jackz007 于 2020-11-15 10:49 编辑
  1. #include <stdio.h>

  2. main()
  3. {
  4.         int b , c , d , e , f , k , r                                         ;
  5.         for(f = 1 ; f ;) {
  6.                 scanf("%d" , & b)                                             ;
  7.                 if(b != -1) {
  8.                         e = (b < 0) ? - b : b                                 ;
  9.                         for(d = e , c = 1 ; d >= 10 ; d /= 10 , c *= 10)      ;
  10.                         for(r = 0 , d = e ; c ; d %= c , c /= 10) {
  11.                                 k = d / c                                     ;
  12.                                 if(k % 2) r = r * 10 + k                      ;
  13.                         }
  14.                         if(r && b < 0) r = -r                                 ;
  15.                         printf("%d\n" , r)                                    ;
  16.                 } else {
  17.                         f --                                                  ;
  18.                 }
  19.         }
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-15 19:25:48 | 显示全部楼层
感谢!!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-9 10:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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