回答第 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;
}
}
|