史萊姆論壇

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

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

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

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

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2010-07-21, 04:40 PM   #1
h4772995
註冊會員
榮譽勳章

勳章總數
UID - 341131
在線等級: 級別:0 | 在線時長:0小時 | 升級還需:5小時
註冊日期: 2010-07-19
文章: 2
精華: 0
現金: 2 金幣
資產: 2 金幣
預設 疑問 - C語言數字排序問題

#include <stdio.h>
#include <stdlib.h>

typedef struct node_t
{
int num;
struct node_t *next;
} NODE;

void listNode(NODE *node,int num)
{
NODE *ptr=node;
if (!node) return;
while (ptr->next) ptr=ptr->next;
if (ptr->next = (NODE *)calloc(sizeof(NODE),1))
ptr->next->num=num;
}

void deleteNode(NODE *node)
{
if (node)
{
deleteNode(node->next);
free(node);
}
}

int Sort(NODE *node)
{
NODE *tmp;
if (node->next && node->next->next)
{
if (node->next->num > node->next->next->num)
{
tmp = node->next;
node->next = node->next->next;
tmp->next = node->next->next;
node->next->next = tmp;
return 1;
}
else return Sort(node->next);
}
else return 0;
}

int main()
{
int num;
NODE root ={0,}, *ptr;
do
{ printf("input number:");
scanf("%d",&num);
if (num)
{ listNode(&root,num);
while (Sort(&root));
for (ptr=root.next; ptr; ptr=ptr->next)
printf("->%d",ptr->num);
printf("\n");
}
} while (num);
deleteNode(root.next);
}

我該如何改成更有效率的排序?
排序程式的部份 我該怎麼改...
h4772995 目前離線  
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
發文 回覆



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

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

相似的主題
主題 主題作者 討論區 回覆 最後發表
請問Office Xp語言介面問題 chauchau 硬體疑難使用問題討論區 6 2003-08-14 07:37 PM
裝了在微軟下載的WINDOWS SERVER 2003英文版..語言問題 fbi1985 軟體應用問題討論區 0 2003-06-19 02:14 AM
請問要看日.韓語言網頁的問題? kana6468 一般電腦疑難討論區 1 2003-06-13 12:51 PM
WINXP PRO 語言修改問題 xxxeee 軟體應用問題討論區 2 2003-05-29 09:02 PM
請問xp繁體語言包的問題.... 721017 一般電腦疑難討論區 3 2003-04-27 02:38 PM


所有時間均為台北時間。現在的時間是 06:40 PM


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


SEO by vBSEO 3.6.1