編寫一個將整數n(1 <= n <= 9999)轉換成羅馬數字。
- 整數n(1<=n<=9999)與羅馬數字表示有以下對應關系
- 1000 - m,有幾個1000就有幾個m對應
- 900 - 兩個字符cm
- 500 - 一個字符d
- 400 - 兩個字符cd
- 100 - 一個字符c,有幾個100就用幾個c表示
- 90 - 兩個字符xc
- 50 - 一個字符l
- 40 - 兩個字符xl
- 10 - 一個字符x,有一個10就用幾個x
- 9 - 用兩個字符ix表示
- 5 - 用一個字符v來表示
- 4 - 用兩個字符iv表示
- 1 - 用一個字符i表示,有幾個1就用幾個i
假如說我們有一個數字22,那么它轉換的方式為22-10=12>=0;
則肯定先有一個x,接著12-10=2>=0;則接著在x后面加上x 變為xx;2-1=1>=0;則肯定后面還需要添加一個i變為xxi,1-1=0>=0;后面還要添加一個i變為xxii。
這樣我們可以這樣做,將對應的羅馬數字和對應的數字放到兩個二維數組中一一對應。
~~~
char *roman[ROW][COLUMN] = {
{"m","m","m","m"},
{"cm","d","cd","c"},
{"xc","l","xl","x"},
{"ix","v","iv","i"}
};
int num[ROW][COLUMN] = {
{1000,1000,1000,1000},
{900,500,400,100},
{90,50,40,10},
{9,5,4,1}
};
~~~
這樣每一個數字進入之后,從數字數組的第一個元素開始,進行減法,如果差大于等于0,接著對這個數字進行減法操作,如果小于0了,則進入下一個數字進行同樣的減法操作,每次差大于等于0的時候,在后面添加上對應的羅馬數字。則轉換算法應該是這樣的。
~~~
/**
* @brief toRoman 將數字轉換成羅馬數字保存到數組rom中
* @param number 要被轉換的數字
* @param rom 將轉換后的羅馬數字保存到rom數組中
*/
void toRoman(int number,char rom[]){
int temp = number;
int i,j;
rom[0]='\0';
for(i = 0;i < ROW;i++){
for(j = 0;j < COLUMN;j++){
while((temp-num[i][j]) >= 0){
strcat(rom,roman[i][j]);
temp = temp-num[i][j];
}
}
}
}
~~~
好了,主體函數已經有了,現在附上我的整體的代碼:
~~~
#include <stdio.h>
#include <string.h>
#define ROW 4
#define COLUMN 4
void toRoman(int number,char rom[]);
/**
* @brief main 編寫一個將整數(1 <= x <= 9999)轉化成對應的羅馬數字的程序
* @return
*/
/**
* 整數n(1<=n<=9999)與羅馬數字表示有以下對應關系
* 1000 - m,有幾個1000就有幾個m對應
* 900 - 兩個字符cm
* 500 - 一個字符d
* 400 - 兩個字符cd
* 100 - 一個字符c,有幾個100就用幾個c表示
* 90 - 兩個字符xc
* 50 - 一個字符l
* 40 - 兩個字符xl
* 10 - 一個字符x,有一個10就用幾個x
* 9 - 用兩個字符ix表示
* 5 - 用一個字符v來表示
* 4 - 用兩個字符iv表示
* 1 - 用一個字符i表示,有幾個1就用幾個i
*
*/
/**
* 用兩個二維數組保存整數和羅馬數字的
* 對應關系
*/
char *roman[ROW][COLUMN] = {
{"m","m","m","m"},
{"cm","d","cd","c"},
{"xc","l","xl","x"},
{"ix","v","iv","i"}
};
int num[ROW][COLUMN] = {
{1000,1000,1000,1000},
{900,500,400,100},
{90,50,40,10},
{9,5,4,1}
};
int main(int argc,char *argv[])
{
int low,high;
if(argc < 2){
printf("Please enter the range of the numbers.\n");
}else if(argc == 2){
low = 1;
high = atoi(argv[1]);
}else if(argc == 3){
low = atoi(argv[1]);
high = atoi(argv[2]);
}else{
printf("There is more params!!\n");
}
int i = low;
for(i = low;i <= high;i++){
char rom[25];
toRoman(i,rom);
printf("%d => %s\n",i,rom);
}
return 0;
}
/**
* @brief toRoman 將數字轉換成羅馬數字保存到數組rom中
* @param number 要被轉換的數字
* @param rom 將轉換后的羅馬數字保存到rom數組中
*/
void toRoman(int number,char rom[]){
int temp = number;
int i,j;
rom[0]='\0';
for(i = 0;i < ROW;i++){
for(j = 0;j < COLUMN;j++){
while((temp-num[i][j]) >= 0){
strcat(rom,roman[i][j]);
temp = temp-num[i][j];
}
}
}
}
~~~
下面是我的程序的輸出結果:

- 前言
- 實例一:HelloWorld
- scanf函數學習
- 實數比較
- sizeof()保留字獲取類型的大小
- 自增/自減學習
- C學習if條件判斷和for循環
- C實現的九九乘法表
- C實現一個比較簡單的猜數游戲
- 使用C模擬ATM練習switch..case用法
- 記錄一個班級的成績練習一維數組
- C數組實現矩陣的轉置
- C二維數組練習
- 利用數組求前n個質數
- C實現萬年歷
- C實現數組中元素的排序
- C實現任意進制數的轉化
- C判斷一個正整數n的d進制數是否是回文數
- C使用遞歸實現前N個元素的和
- 鋼材切割問題
- 使用指針比較整型數據的大小
- 指向數組的指針
- 尋找指定元素
- 尋找相同元素的指針
- 整數轉換成羅馬數字
- 字符替換
- 從鍵盤讀入實數
- C實現字符行排版
- C實現字符排列
- C實例--判斷一個字符串是否是回文數
- 通訊錄的輸入輸出
- 撲克牌的結構定義
- 使用“結構”統計學生成績
- 報數游戲
- 模擬社會關系
- 統計文件中字符個數
- C實現兩個文件的內容輸出到同一個屏幕