| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1918 人关注过本帖
标题:整数各位取偶数 pk思路
只看楼主 加入收藏
浅水无殇
Rank: 2
等 级:论坛游民
帖 子:123
专家分:75
注 册:2012-11-23
结帖率:100%
收藏
已结贴  问题点数:40 回复次数:27 
整数各位取偶数 pk思路
将一个整数中的每一位上为偶数的数依次取出,构成一个新数放在t中。高位仍在高位,低位仍在低位。例如,当s中的数为:87653142时,t中的数为:8642
输入描述:
输入数据为一个不大于100000000的整形数;
输出描述:
输出数据为一个不大于100000000的整形数;
样式输入:
987654321
样式输出:
8642
我的思路 第一种是传统的循环取余。。。再判断。。
第二种是用字符串。。指针。。嘿嘿。。
话说。。今天晚上要考试。。好辛苦的说。。
 
搜索更多相关主题的帖子: 字符串 
2013-01-07 15:22
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:10 
不超过_int64的话就取模呗   还不是很快的

DO IT YOURSELF !
2013-01-07 15:24
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:10 
支持字符串+指针

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-07 15:29
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
第二种 是 第一种加无用功
所以我选第一种
2013-01-07 15:41
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:0 
循环取余不也是要把每一位都单独拿出来吗

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-07 15:44
浅水无殇
Rank: 2
等 级:论坛游民
帖 子:123
专家分:75
注 册:2012-11-23
收藏
得分:0 
以下是引用rjsp在2013-1-7 15:41:06的发言:

第二种 是 第一种加无用功
什么意思。。。。

wula wual
2013-01-07 15:51
yaobao
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:4
帖 子:1854
专家分:4121
注 册:2012-10-25
收藏
得分:0 
我也没明白为什么这样说

认认真真的学习,踏踏实实的走路:戒骄戒躁!!!
2013-01-07 15:52
浅水无殇
Rank: 2
等 级:论坛游民
帖 子:123
专家分:75
注 册:2012-11-23
收藏
得分:0 
程序代码:
#include<stdio.h>
#include<string.h>
main()
{
char *p;
int i,j;
char a[80];
p=a;
scanf("%s",a);
j=strlen(a);
for(i=0;i<j;i++)
{
    if((a[i]-'0')%2==0) //其实,我在课堂没学到。。这里减‘0’是什么意思。。
    printf("%c",*(p+i));
}
}

wula wual
2013-01-07 15:57
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
我贴一个数值型的  就是写的啰嗦了点
程序代码:
#include <stdio.h>

int main(int argc, char* argv[])
{
    _int64 m=9223372036854775807;
    _int64 out=0;
    int tmp=0,tmp2;
    int i=0,j=0;
    while(1)
    {
        tmp=(m%10)%2;
        if(tmp==0)
        {
            tmp2=m%10;
            for(i=0;i<j;i++)
            {
                tmp2=tmp2*10;
            }
            out=out+tmp2;
            j++;
        }
        m=m/10;
        if (m<=0) break;
    }
    printf("%I64d\n",out);
    return 0;
}


DO IT YOURSELF !
2013-01-07 16:04
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
a[i]-'0'  就是把字符型数字变成数值型数字

DO IT YOURSELF !
2013-01-07 16:05
快速回复:整数各位取偶数 pk思路
数据加载中...
 
   



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

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