rome2arabic
This commit is contained in:
		
							parent
							
								
									b541e00bad
								
							
						
					
					
						commit
						4ae6c94abc
					
				
					 1 changed files with 38 additions and 0 deletions
				
			
		
							
								
								
									
										38
									
								
								numbers/rome2arabic.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								numbers/rome2arabic.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <string.h> | ||||||
|  | #define LEN 7 | ||||||
|  | 
 | ||||||
|  | const char rome[] = {'I', 'V', 'X', 'L', 'C', 'D', 'M'}; | ||||||
|  | const int arabic[] = {1, 5, 10, 50, 100, 500, 1000}; | ||||||
|  | 
 | ||||||
|  | int find_eq(char c); | ||||||
|  | 
 | ||||||
|  | int main() { | ||||||
|  | 	int cur, next; | ||||||
|  | 	int res = 0; | ||||||
|  | 	int i; | ||||||
|  | 	char s[4000]; | ||||||
|  | 
 | ||||||
|  | 	scanf("%s", s); | ||||||
|  | 	 | ||||||
|  | 	for (i = 0; i < (int)strlen(s) - 1; ++i) { | ||||||
|  | 		cur = find_eq(s[i]); | ||||||
|  | 		next = find_eq(s[i+1]);  | ||||||
|  | 		if (cur < next) { | ||||||
|  | 			res -= cur; | ||||||
|  | 		} | ||||||
|  | 		else  | ||||||
|  | 			res += cur; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	res += find_eq(s[i]); | ||||||
|  | 
 | ||||||
|  | 	printf("%d", res); | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int find_eq(char c) { | ||||||
|  | 	int i; | ||||||
|  | 	for (i = 0; (c != rome[i]) && (i < LEN); ++i);	 | ||||||
|  | 	return arabic[i]; | ||||||
|  | } | ||||||
		Reference in a new issue