『壹』 設計一個演算法,從五個不同的數中找出最大數,用流程圖描述這個演算法.
答案:解析: 記這五個不同的數分別為a1、a2、a3、a4、a5,演算法步驟如下: S1比較a1與a2,將較大的數記作b;(在這一步中,b表示的是前兩個數中的最大數) S2再將b與a3進行比較,將較大的數...
『貳』 用C語言設計個演算法,比較三個數的演算法從大到小輸出
#include <stdio.h>
int main(void)
{
int i,a[3];
printf("enter 3 numbers:");//輸入3個書
for(i=0;i<3;i++)
{
scanf("%d",&a[i]);
if(a[i]>a[0]) a[i]=a[0]+a[i]-(a[0]=a[i]);//把最大的放在a〔0〕,就只要比較一次就行了。
}
if(a[1]<a[2]) a[1]=a[2]+a[1]-(a[2]=a[1]);
printf("The number from max to low:");
for(i=0;i<3;i++)
printf("%d\t",a[i]);
printf("\n");
return 0;
}
『叄』 設計一個演算法,當給定數字0,1,2.3,4,5,6,7, 8,9的一個排列時
用fortran寫了一段代碼,具體演算法見綠色字體注釋。
供您參考。
附:fortran代碼和4個運行示例
『肆』 設計演算法找出三個數中的最大值
有a,b,c三個數,比較它們的大小
方法一,按順序兩兩比較,取較大的
if (a > b) {
max = a;
} else {
max = b;
}
if (max < c) {
max = c;
}
方法二,假設第一個是最大的,與後面兩個數進行比較,將較大的值賦給max
int max = a;
if (b > max) {
max = b;
}
if (c > max) {
max = c;
}
1、什麼是演算法
演算法(algorithm):就是定義良好的計算過程,他取一個或一組的值為輸入,並產生出一個或一組值作為輸出。簡單來說演算法就是一系列的計算步驟,用來將輸入數據轉化成輸出結果。
mark:我們可以把所有的演算法想像為一本「菜譜」,特定的演算法比如菜譜中的的一道「老醋花生米」的製作流程,只要按照菜譜的要求製作老醋花生米,那麼誰都可以做出一道好吃的老醋花生米。so,這個做菜的步驟就可以理解為:「解決問題的步驟」
2、演算法的意義
假設計算機無限快,並且計算機存儲容器是免費的,我們還需要各種亂七八糟的演算法嗎?如果計算機無限快,那麼對於某一個問題來說,任何一個都可以解決他的正確方法都可以的!
當然,計算機可以做到很快,但是不能做到無限快,存儲也可以很便宜但是不能做到免費。
那麼問題就來了效率:解決同一個問題的各種不同演算法的效率常常相差非常大,這種效率上的差距的影響往往比硬體和軟體方面的差距還要大。
3、如何選擇演算法
第一首先要保證演算法的正確性
一個演算法對其每一個輸入的實例,都能輸出正確的結果並停止,則稱它是正確的,我們說一個正確的演算法解決了給定的計算問題。不正確的演算法對於某些輸入來說,可能根本不會停止,或者停止時給出的不是預期的結果。然而,與人們對不正確演算法的看法想反,如果這些演算法的錯誤率可以得到控制的話,它們有時候也是有用的。但是一般而言,我們還是僅關注正確的演算法!
第二分析演算法的時間復雜度
演算法的時間復雜度反映了程序執行時間隨輸入規模增長而增長的量級,在很大程度上能很好反映出演算法的好壞。