数字过滤
题目描述给定一批整数,经每个整数中各位上为偶数的数字去掉,在顺次排列得到一个新的整数。并输出。
例如一个整数15236,转换后为153
输入:
每行一个待转换的整数,最后一个-1表示结束。
(-1不用转换)
输出:
n行,转换后的整数。
样例输入
152435
126523
5623561
-1
样例输出
1535
153
5351
提示
如果没有奇数,则输出0 #include<stdio.h>
#include <stdlib.h>
#include <string.h>
int Trim(int num)
{
int i = 0;
int len = 0;
char buffer = {0};
sprintf(buffer,"%d",num);
len = strlen(buffer);
for(i=0 ; i<len ; )
{
if(buffer!='-' && buffer%2==0)
{
memcpy(buffer+i,buffer+i+1,len-i-1);
buffer[--len] = 0;
}
else
{
i++;
}
}
return(atoi(buffer));
}
int main()
{
int arr = {0};
int count = 0;
int i = 0;
for(count=0 ; count<10 ; count++)
{
scanf("%d",&i);
if(i == -1)
{
break;
}
arr = i;
}
for(i=0 ; i<count ;i++)
{
printf("%d\n",Trim(arr));
}
return 0;
}
本帖最后由 jackz007 于 2020-11-15 10:49 编辑
#include <stdio.h>
main()
{
int b , c , d , e , f , k , r ;
for(f = 1 ; f ;) {
scanf("%d" , & b) ;
if(b != -1) {
e = (b < 0) ? - b : b ;
for(d = e , c = 1 ; d >= 10 ; d /= 10 , c *= 10) ;
for(r = 0 , d = e ; c ; d %= c , c /= 10) {
k = d / c ;
if(k % 2) r = r * 10 + k ;
}
if(r && b < 0) r = -r ;
printf("%d\n" , r) ;
} else {
f -- ;
}
}
} 感谢!!
页:
[1]