- 1、python流程圖繪製?
- 2、煩請幫忙畫兩個簡單的python流程圖
- 3、實現一個根據python代碼自動生成流程圖難度有多大
- 4、大家大家,請問這個python代碼怎麼轉換成流程圖啊?需要比較規範的!
- 5、什麼軟體可以實現流程圖自動生成源代碼?
- 6、根據程序代碼畫流程圖和根據流程圖自動寫代碼的程序 怎麼做
自動生成流程圖
基於Python和Graphviz開發的,能將源代碼轉化為流程圖的工具:pycallgraph 可以幫到你;
跟著參考文章操作,親測有效;
參考文章:Python 流程圖 — 一鍵轉化代碼為流程圖
流程圖畫了之後,沒法往上傳啊,截圖的話,估計會看不清楚。這個應該是很簡單的,先用一個循環,求出來平均值。再用一個循環,比較一下就可以解決第一問。找出平均值之後,用一個循環減去平均值,放到數組裡,找一個最小的,可解決第二問。第三問還是循環比較。自己直接用word畫也是很快的。
用dis模塊去看bytecode,關注一下帶JUMP的指令和CALL_FUNCTION相關的指令可以找到分支、跳轉和函數調用的相關信息(可以找到跳轉和調用的條件,目標,op在source的line number等等信息),再結合inspect的getsource一系列函數應該差不多了。
如果這樣可行的話,難度不大。
當然,ast模塊去看ast應該也行。不過我之前一些項目經驗讓我更喜歡直接去看bytecode。
你要的這個流程圖,是輔助代碼理解的,通常是在學習過程中、或者一些代碼塊的分析中用到。
實際項目幾乎用不到,而且實際項目業務邏輯複雜,要生成你說的流程圖是很困難的。有複雜,對生產力又沒有幫助,自然沒有人會去做這樣的程序。
所以還是自己畫吧。
什麼軟體可以實現流程圖自動生成源代碼?
為了減少手寫代碼的錯誤,考慮通過流程圖方式自動生成代碼(C語言),不知什麼工具能做到,收費工
char a,b,c;
{if (n==1) printf(“%c–%c\n”,a,c);
else {hanoi (n-1,a,c,b);
printf (“%c–%c\n”,a,c);
hanoi (n-1,b,a,c);}
}
我給你詳細解釋下這個程序中的代碼吧。我也是剛學,希望對你有用。可能有些不好之處,還希望諒解。
先說下這個問題的整體思想:
1,如果只有1個盤,那麼就直接把這個盤從A移動到C上。
2,如果存在兩個盤,那麼先把第一個盤移動到B上,在把最下面一個盤移動到C上,在把B上的盤移動到C上。
3,這樣,我們可以得出一個結論,如果存在N個盤,可以先把上面N-1個盤通過C 移動到B上,然後把第N個盤移動到C上, 再把B上的N個盤通過A移動到C上。
if (n==1) printf(“%c–%c\n”,a,c);
這一句,表示只有1個盤子的時候,那麼就是把第一個盤子直接移到第三個盤子上。
else {hanoi (n-1,a,c,b);
如果超過一個盤字,則需要先把N-1個盤子通過C 移動到B上。
printf (“%c–%c\n”,a,c);
把剩下的第N個盤,從A移動到C上。
hanoi (n-1,b,a,c);}
再把剩下的在B上的N-1個盤,通過A移動到C上。
這屬於一個遞歸演算法。
現在,N=3。
我們看下程序怎麼運行的。
else {hanoi (n-1,a,c,b);
printf (“%c–%c\n”,a,c);
hanoi (n-1,b,a,c);}
N=3,也就是開始程序會執行
hanoi (2,a,c,b);這句語句。
再看,2還是大於1,所以
程序會繼續運行。 注意,這裡,為hanoi (2,a,c,b); C和B 換了位置。
hanoi (2,a,c,b);
我們把數字代入,得出。
根據 N=2,C和B 互換。以及下面的代碼,得出
““““““““““““““““““““““““
hanoi(n,a,b,c)
int n;
char a,b,c;
{if (n==1) printf(“%c–%c\n”,a,c);
else {hanoi (n-1,a,c,b);
printf (“%c–%c\n”,a,c);
hanoi (n-1,b,a,c);}
}
“““““““““““““““““““““““`
hanoi(2,a,c,b)
int n=2;
char a,c,b;
{if (n==1) printf(“%c–%c\n”,a,b);
else {hanoi (1,a,b,c);
printf (“%c–%c\n”,a,b);
hanoi (1,c,a,b);}
} / 這並不是正確的代碼,只是為了得出答案而寫的一些數據。/
這樣, 我們可以看出,程序會先執行
else {hanoi (1,a,b,c);
所以,開始會先輸出A C(中間的符號省略,以下也一樣)
然後,再輸出
printf (“%c–%c\n”,a,b); A B
接著,執行
hanoi (1,c,a,b);} 這時候,就是C B了。
也就是說 hanoi(2,a,c,b) 的輸出為 AC AB CB
你的問題就已經解決了。
接下來再返回第一層:
現在,N=3。
我們看下程序怎麼運行的。
else {hanoi (n-1,a,c,b);
printf (“%c–%c\n”,a,c);
hanoi (n-1,b,a,c);}
這時候,我們再把數字代進去。
現在,N=3。
我們看下程序怎麼運行的。
else {hanoi (2,a,c,b);
printf (“%c–%c\n”,a,c);
hanoi (2,b,a,c);}
根據上面的結論
/ 也就是說 hanoi(2,a,c,b) 的輸出為 AC AB CB /
可以看出,先執行第一條語句:
else {hanoi (2,a,c,b);
則輸出 AC AB CB
再執行第二條語句:
printf (“%c–%c\n”,a,c);
輸出 AC
然後執行第三條
hanoi (2,b,a,c);}
根據這裡,/ 也就是說 hanoi(2,a,c,b) 的輸出為 AC AB CB /
字母進行替代後,A變B,C變A B變C。
所以輸出的AC AB CB 則為
BA BC AC
所以,最終的結果為 AC AB CB AC BA BC AC
中間可能有很多廢話,可以不看。
這樣算下去,不管多少層都能推算出來,可複雜度會高得難以想像。
原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/127154.html