![]() |
|
|||||||
| 論壇說明 |
|
歡迎您來到『史萊姆論壇』 ^___^ 您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的! 請點擊這裡:『註冊成為我們的一份子!』 |
![]() |
|
|
主題工具 | 顯示模式 |
|
|
#1 |
|
註冊會員
|
題目:
輸入一個數字B,以B為進位數(ex:B=2,以2進位),2<=B<=20 接著在1<=N<=300的情況下,以B為進位數的N平方數M若為對稱數 則以B為進位的方式輸出N及M EX:B=2,N=3,N平方=9=1001(以2為底),則1001為一對稱數 B=2,N=4,N平方=16=10000(以2為底),則10000為一不對稱數 忘了提醒~ 若是數字進位後超過10,以英文表示,ex:30(B=16)=1E 範例輸入: 10 範例輸出: 1 1 2 4 3 9 11 121 22 484 26 676 101 10201 111 12321 121 14641 202 40804 212 44944 264 69696 題目來源 +U!! 10/1 給解答測試~ 此帖於 2007-08-27 12:16 AM 被 joebin 編輯. |
|
|
送花文章: 15,
|
|
|
#3 (permalink) |
|
註冊會員
|
用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);
}
|
|
|
送花文章: 2,
|
|
|
#4 (permalink) |
|
註冊會員
|
各位看官想知道自己答案正確還是錯誤請按
然後在自己程式碼前打上 語法:
/* ID: newjoeb1 PROG: palsquare LANG: 選擇語言名稱(C.C++.PASCAL.JAVA) */ 以下是我的程式碼(好長.....僅供參考 = =) 語法:
/*
ID: newjoeb1
PROG: palsquare
LANG: C++
*/
#include <iostream>
#include <fstream>
#include <string>
#include <math.h>
using namespace std;
int main() {
ofstream fout ("palsquare.out");
ifstream fin ("palsquare.in");
int i,j,m,k,n,l=1,t; char d[301][20],A='A',O='0',a[20];
fin >>n;
for(i=1;i<=300;i++){
m=i*i;k=pow(n,l);t=1;
if(m/k>0)
while(m/k>0){
l++;
k=pow(n,l);
}
for(j=l-1;j>=0;j--){
k=pow(n,j);
d[i][j]=m/k;
m%=k;
}
for(j=l;j>l/2;j--)
if(d[i][j-1]!=d[i][l-j]){
t=0;
break;
}
if(t==1){
j=0;m=i;
while(m>0){
a[j]=m%n;
m/=n;
j++;
}
for(;j>0;j--){
if(a[j-1]>9){
A+=a[j-1]-10;
fout <<A;
A='A';
}
else{
O+=a[j-1];
fout <<O;
O='0';
}
}
fout <<" ";
for(j=l-1;j>=0;j--){
if(d[i][j]>9){
A+=d[i][j]-10;
fout <<A;
A='A';
}
else{
O+=d[i][j];
fout <<O;
O='0';
}
}
fout <<endl;
}
}
return 0;
}
|
|
|
送花文章: 15,
|