當前位置:首頁 » 操作系統 » 演算法編寫

演算法編寫

發布時間: 2022-02-05 03:25:02

A. 數據結構編寫演算法

Node * min = list->head; //minmum node
Node * prv = NULL; //prv's link is the minmum node
while p! = NULL // find the mimimum
if min->data>p->data
min = p; //每找到一個比當前minmun更小的節點,則讓P指向這個節點。
end if
prv = p; //讓prv的始終指向p的前一個節點
p = p->link;
end while
if prv != NULL // prv is changed,reset the links
prv->link = p->link; //下面3行:讓p前面的節點指向p後面的節點
//(p就不在鏈表裡了),然後p指向head,並
//把鏈表的head設為p
p->link = list->head;
list->head = p;
end if
//else head is the minmum node

///註:沒有用malloc申請新的節點,只是申請了新的節點的指針。

//稍微完善了一下,修正了幾個錯誤並寫了注釋,樓主可以看著給分吧,強烈bs那個我東西的人。寫軟體的最煩的就是你這種人。

B. 編寫數據結構演算法

1、編寫刪除單鏈表中值為X的演算法。
typedef struct LNode
{ int data;
struct LNode *next;
}LinkList;
void del(LinkList *&L,int value) {
LinkList *p;
while(L->next!=NULL){
p=L->next;
if(p->data==value)
L->next=p->next;
delete p;
L=L->next;
}
}

2、編寫演算法計算指定子串在一個字元串中出現的次數
typedef struct
{
char data[100];
int len;
}SqString;
int StrCount(SqString *substr,SqString *str){
int flag=1,count;
for (int i=0;i<str->len-substr->len;i++){
flag=1;
for (int j=0;j<substr->len;j++)
if (*(substr+j)!=*str) flag=0;
if (flag==1) count++;
}
return count;
}

C. 演算法實現

多看一些源代碼最好,先動手編一些簡單的程序,程序能力的提高都是靠看靠編出來的,理論不用很到位的面面具到的都非常懂會用最好,遇到問題會查閱資料。參考書籍的話:c就是譚浩強那本比較經典了,外國書是好但看起來費勁。c++就清華的潛能也不錯。你直接學《數據結構和演算法分析設計》這門課不太合理,因為得有一些基礎和編程經驗在學會更好一些。
多去csdn學習,多尋找一些好的源代碼看看。這樣學起來很快而且不枯燥,如果一味得看書你會煩得不行也沒有盡頭,邊學邊練習會極大增強信心。

D. C語言演算法的編寫

同學你好,通過找規律可以得到,當n為偶數時,結果為0,n為奇數時,結果為-1;
所以直接用if條件語句判斷一下就好啦!
望採納,謝謝!

E. 求編寫演算法

先開兩個數組s和q, s存放棧中的數據,q存放隊列中的數據,遍歷棧S,碰到奇數就把數據放到數組q中,碰到偶數就放到數組s中,然後再把數組s和q中的數據分別插入到棧S和隊列Q中即可。

F. 演算法編寫方法

C語言程序也是演算法的一種形式,以後老師讓你寫演算法的時候你就寫程序吧,他會給你滿分的。

演算法是一種簡化的、抽象的程序,是通俗語言加上一些邏輯格式對程序過程的描述,它不是程序,但是所有的程序員都能把它翻譯為自己會的那種程序。

G. 編程演算法是什麼

程序演算法是對特定問題求解過程的描述,是指令的有限序列,每條指令完成一個或多個操作。通俗地講,就是為解決某一特定問題而採取的具體有限的操作步驟。

在有限的操作步驟內完成。有窮性是演算法的重要特性,任何一個問題的解決不論其採取什麼樣的演算法,其終歸是要把問題解決好。如果一種演算法的執行時間是無限的,或在期望的時間內沒有完成,那麼這種演算法就是無用和徒勞的,我們不能稱其為演算法。

相關信息:

演算法的時間復雜度是指演算法需要消耗的時間資源。一般來說,計算機演算法是問題規模n 的函數f(n),演算法的時間復雜度也因此記做T(n)=Ο(f(n));因此,問題的規模n 越大,演算法執行的時間的增長率與f(n) 的增長率正相關,稱作漸進時間復雜度(Asymptotic Time Complexity)。

演算法的空間復雜度是指演算法需要消耗的空間資源。其計算和表示方法與時間復雜度類似,一般都用復雜度的漸近性來表示。同時間復雜度相比,空間復雜度的分析要簡單得多。

H. 編寫演算法

int Count(BTreeNode* BT)
{
int nLeftLeave, nRightLeave;
if( (BT->Left == NULL) && (BT->Right == NULL) )
return 1; // leave node
if( BT->Left != NULL )
nLeftLeave = Count(BT->Left);
if( BT->Right != NULl)
nRightLeave = Count(BT->Right);
return nLeftLeave + nRightLeave;
}

雖然晚了點;不過我就是喜歡遞歸

I. 請問演算法和編程的區別,最好能舉例

解決一個問題,有不同的解決方法。
這就是演算法。
比如:1 + 2 + 。。。100 = 5050。
顯然,有不同的演算法。

編程,是跟著演算法來的。
當然,同樣的演算法,也能寫出不同的程序結構。
這就是經驗的問題了。

J. 如何編寫高效的演算法

我也在看演算法導論..那本書太恐怖了....

學演算法是肯定需要數學基礎的 所以...數學再加油吧

熱點內容
斷點上傳續傳 發布:2025-01-11 15:50:23 瀏覽:247
編程說明文 發布:2025-01-11 15:50:21 瀏覽:698
格式化數組php 發布:2025-01-11 15:43:52 瀏覽:7
伺服器能查ip嗎 發布:2025-01-11 15:27:36 瀏覽:911
住宅燈如何配置 發布:2025-01-11 15:27:35 瀏覽:620
手機取款密碼在哪裡設置 發布:2025-01-11 15:17:28 瀏覽:970
安卓手機飢荒在哪裡下 發布:2025-01-11 15:16:27 瀏覽:834
壓縮軟膠 發布:2025-01-11 15:10:08 瀏覽:971
安卓怎麼恢復刪除照片恢復軟體 發布:2025-01-11 14:55:49 瀏覽:172
空調壓縮機皮帶打滑 發布:2025-01-11 14:55:10 瀏覽:62