奇偶個數 數字特徵值(第三日習題)

2022-08-14 02:09:25 字數 1575 閱讀 4768

1、奇偶個數

題目內容:

你的程式要讀入一系列正整數資料,輸入-1表示輸入結束,-1本身不是輸入的資料。程式輸出讀到的資料中的奇數和偶數的個數。

輸入格式:

一系列正整數,整數的範圍是(0,100000)。如果輸入-1則表示輸入結束。

輸出格式:

兩個整數,第乙個整數表示讀入資料中的奇數的個數,第二個整數表示讀入資料中的偶數的個數。兩個整數之間以空格分隔。

輸入樣例:

9 3 4 2 5 7 -1

輸出樣例:

4 2時間限制:500ms 記憶體限制:32000kb

程式參考:

#include

int main()

else

//讀接下來的數,重新開始迴圈

scanf("%d",&number);

}//輸出

printf("%d %d",a,b);

return 0;

}2、數字特徵值

題目內容:

對數字求特徵值是常用的編碼演算法,奇偶特徵是一種簡單的特徵值。對於乙個整數,從個位開始對每一位數字編號,個位是1號,十位是2號,以此類推。這個整數在第n位上的數字記作x,如果x和n的奇偶性相同,則記下乙個1,否則記下乙個0。按照整數的順序把對應位的表示奇偶性的0和1都記錄下來,就形成了乙個二進位制數字。比如,對於342315,這個二進位制數字就是001101。

這裡的計算可以用下面的**來表示:

數字數字

數字奇偶奇偶

偶奇奇奇

數字奇偶偶奇

偶奇偶奇

奇偶一致

二進位制位值

按照二進位制位值將1的位的位值加起來就得到了結果13。

你的程式要讀入乙個非負整數,整數的範圍是[0,100000],然後按照上述演算法計算出表示奇偶性的那個二進位制數字,輸出它對應的十進位制值。

輸入格式:

乙個非負整數,整數的範圍是[0,100000]。

輸出格式:

乙個整數,表示計算結果。

輸入樣例:

輸出樣例:

時間限制:500ms 記憶體限制:32000kb

程式參考:

#include

#include

int main()

else

c++;

//將此時的數字右起第一位劃掉

x/=10;

}//輸出

printf("%d",y);

return 0;

}感想:

第一題沒有什麼問題。

第二題為了簡化程式,查詢並使用了冪函式的寫法。(雖然學長指點說冪函式也可以自己寫,但是我還沒有動手去嘗試。)

不使用冪函式的話,我可能寫不出足夠簡潔的程式。

第四周程式設計練習 奇偶個數 數字特徵值

題目內容 你的程式要讀入一系列正整數資料,輸入 1表示輸入結束,1本身不是輸入的資料。程式輸出讀到的資料中的奇數和偶數的個數。輸入格式 一系列正整數,整數的範圍是 0,100000 如果輸入 1則表示輸入結束。輸出格式 兩個整數,第乙個整數表示讀入資料中的奇數的個數,第二個整數表示讀入資料中的偶數的...

數字特徵值

題目內容 對數字求特徵值是常用的編碼演算法,奇偶特徵是一種簡單的特徵值。對於乙個整數,從個位開始對每一位數字編號,個位是1號,十位是2號,以此類推。這個整數在第n位上的數字記作x,如果x和n的奇偶性相同,則記下乙個1,否則記下乙個0。按照整數的順序把對應位的表示奇偶性的0和1都記錄下來,就形成了乙個...

數字特徵值

題目內容 對數字求特徵值是常用的編碼演算法,奇偶特徵是一種簡單的特徵值。對於乙個整數,從個位開始對每一位數字編號,個位是1號,十位是2號,以此類推。這個整數在第n位上的數字記作x,如果x和n的奇偶性相同,則記下乙個1,否則記下乙個0。按照整數的順序把對應位的表示奇偶性的0和1都記錄下來,就形成了乙個...