查看單個文章
舊 2007-08-26, 03:31 PM   #3 (permalink)
wenneng
註冊會員
榮譽勳章
UID - 257587
在線等級: 級別:9 | 在線時長:124小時 | 升級還需:16小時級別:9 | 在線時長:124小時 | 升級還需:16小時級別:9 | 在線時長:124小時 | 升級還需:16小時級別:9 | 在線時長:124小時 | 升級還需:16小時
註冊日期: 2006-11-20
文章: 26
精華: 0
現金: 16 金幣
資產: 16 金幣
預設

用C寫了一個

語法:
#include<stdio.h>
#define snum_MAX 17

void translate(int N, long decimal_num, char *result_num, int *result_digit);
int Is_symmetry(char data[], int digit);
void print_result(int num, char data[], int digit);

void main(){
	int i, B, digit;
	char snum[snum_MAX];
	long num;

	scanf("%d", &B);

	for(i = 1;i <= 300;i++){
		num = (long)i * (long)i;
		translate(B, num, snum, &digit);
		if(Is_symmetry(snum, digit))
			print_result(i, snum, digit);
	}
}

void translate(int N, long decimal_num, char *result_num, int *result_digit){
	*result_digit = 0;
	while(decimal_num){
		*result_num =  decimal_num % N;
		result_num++;
		decimal_num /= N;
		(*result_digit)++;
	}
	*result_num = '\0';
}

int Is_symmetry(char data[], int digit){
	int i, j;

	i = 0;
	j = digit - 1;
	while(data[i] == data[j] && i <= j){
		i++;
		j--;
	}
	return (i > j);
}

void print_result(int num, char data[], int digit){
	while(digit){
		digit--;
		if(data[digit] < 10) data[digit] += 0x30;
		else data[digit] += 0x37;		
	}
	printf("%d\t%s\n", num, data);
}
wenneng 目前離線  
送花文章: 2, 收花文章: 7 篇, 收花: 8 次
回覆時引用此帖