史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


 
 
主題工具 顯示模式
舊 2006-04-16, 09:23 PM   #6 (permalink)
管理員
 
getter 的頭像
榮譽勳章
UID - 6433
在線等級: 級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時級別:96 | 在線時長:9733小時 | 升級還需:64小時
註冊日期: 2002-12-08
住址: 天線星球
文章: 8157
精華: 0
現金: 19955 金幣
資產: 765391 金幣
預設

回答第 2 個問題
編寫的概念上
既然是數字的排列的話...

923678 不管是以整數或是浮點數的形式的話,都只是一個數值,
不能直接進行排序...。

如果 923678 是字串的話,對電腦來說 9 或 2 或 3 或 6 或 7 或 8
都是各佔 1 Byte 的字元,自然能夠排序。

那數值真的不能牌嗎 ? 可以必須以 itoa 來進行轉型(把數值轉換成字串)
當排序作業完成後可以用 atoi 將字串轉換回數值

itoa 的用法
itoa (value,string,radix);
value ︰欲轉換的數值
string︰轉換成字串時放置的字元陣列
radix ︰以哪一種數字系統做轉換(10為10進位、2為2進位、16為16進位)

ex: itoa ( 659817, str01, 10);

atoi 的用法
atoi ( 字元或字串 );

ex: atoi("1963");

因為只有轉換所以要用一個變數去接

ex: i = atoi("1963");

這樣 i 的內容才會有 1963 。


DEV-C 程式 以字串直接處裡
引用:

#include <stdio.h> /* 標準 I/O_函式庫 */
#include <string.h> /* 字串處理_函式庫 */

main()
{
char ca[50] = "";

printf("請輸入數字:");

scanf ("%s",&ca);

printf ("\n排整前:%s",ca);

sort_b ( ca );

printf ("\n排整後:%s",ca);

printf ("\n\n");
system ("PAUSE");
}

sort_b ( char *data )
{
int i, j, k, s;

s = strlen ( data );

for( i=0; i<s; i++ )
{
for( j = k = 0; j<s-1; j++)
{
if ( data[j] > data[j+1] )
{
data[j] ^= data[j+1];
data[j+1] ^= data[j];
data[j] ^= data[j+1];
}
else { k++; }
}
if( k == s - 1 ) break;
}
}
DEV-C 程式 數值接處裡 (需要用到 itoa 來做轉換)

引用:

#include <stdio.h> /* 標準 I/O_函式庫 */
#include <string.h> /* 字串處理_函式庫 */

main()
{
int ia;
char ca[50] = "";

printf("請輸入數字:");

scanf ("%d",&ia);

itoa( ia, ca, 10 ); /* 將數值轉換成字串 */

printf ("\n排整前:%d",ia);

sort_b ( ca );

ia = atoi( ca ); /* 將字串轉換成數值 */

printf ("\n排整後:%d",ia);

printf ("\n\n");
system ("PAUSE");
}

sort_b ( char *data )
{
int i, j, k, s;

s = strlen ( data );

for( i=0; i<s; i++ )
{
for( j = k = 0; j<s-1; j++)
{
if ( data[j] > data[j+1] )
{
data[j] ^= data[j+1];
data[j+1] ^= data[j];
data[j] ^= data[j+1];
}
else { k++; }
}
if( k == s - 1 ) break;
}
}
getter 目前離線  
送花文章: 37855, 收花文章: 6441 篇, 收花: 26052 次
回覆時引用此帖
 



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 02:13 AM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2025, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1