zoukankan      html  css  js  c++  java
  • 第三周:循环

    1
    奇偶个数(5分)

    题目内容:

    你的程序要读入一系列正整数数据,输入-1表示输入结束,-1本身不是输入的数据。程序输出读到的数据中的奇数和偶数的个数。

    输入格式:

    一系列正整数,整数的范围是(0,100000)。如果输入-1则表示输入结束。

    输出格式:

    两个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。

    输入样例:

    9 3 4 2 5 7 -1

    输出样例:

    4 2

    时间限制:500ms内存限制:32000kb
    #include <stdio.h>
    #include <string.h>
    
    
    int main(int argc, const char * argv[]) {
        int inputNumber = 0;
        int oddCount = 0;
        int evenCount = 0;
        while (1) {
            scanf("%d", &inputNumber);
            if(inputNumber == -1){
                break;
            }
            if(inputNumber%2 == 0){
                oddCount++;
            }else{
                evenCount++;
            }
        }
        printf("%d %d
    ",evenCount, oddCount);
        return 0;
    }
    

      

    2
    数字特征值(5分)

    题目内容:

    对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值。对于一个整数,从个位开始对每一位数字编号,个位是1号,十位是2号,以此类推。这个整数在第n位上的数字记作x,如果x和n的奇偶性相同,则记下一个1,否则记下一个0。按照整数的顺序把对应位的表示奇偶性的0和1都记录下来,就形成了一个二进制数字。比如,对于342315,这个二进制数字就是001101。

    这里的计算可以用下面的表格来表示:

    数字

    3

    4

    2

    3

    1

    5

    数位

    6

    5

    4

    3

    2

    1

    数字奇偶

    数位奇偶

    奇偶一致

    0

    0

    1

    1

    0

    1

    二进制位值

    32

    16

    8

    4

    2

    1

    按照二进制位值将1的位的位值加起来就得到了结果13。

    你的程序要读入一个非负整数,整数的范围是[0,100000],然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。

    提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。

     

    输入格式:

    一个非负整数,整数的范围是[0,100000]。

    输出格式:

    一个整数,表示计算结果。

    输入样例:

    342315

    输出样例:

    13

    时间限制:500ms内存限制:32000kb
     
    #include <stdio.h>
    #include <string.h>
    #include <math.h>
    
    int main(int argc, const char * argv[]) {
        int inputNumber;
        scanf("%d", &inputNumber);
        int temp = inputNumber;
        int n;
        int count = 0;
        int totalNumber = 0;
        while (temp!=0) {
            n = temp%10;
            count = count+1;
            temp = temp/10;
            if (n%2== count%2){
                totalNumber += pow(2, count-1);
            }
        }
        printf("%d
    ",totalNumber);
        return 0;
    }
    

      

  • 相关阅读:
    237. Delete Node in a Linked List
    430. Flatten a Multilevel Doubly Linked List
    707. Design Linked List
    83. Remove Duplicates from Sorted List
    160. Intersection of Two Linked Lists
    426. Convert Binary Search Tree to Sorted Doubly Linked List
    142. Linked List Cycle II
    类之间的关系
    初始化块
    明确类和对象
  • 原文地址:https://www.cnblogs.com/ColaZhang/p/5933659.html
Copyright © 2011-2022 走看看