วันศุกร์ที่ 23 สิงหาคม พ.ศ. 2556
วันพฤหัสบดีที่ 1 สิงหาคม พ.ศ. 2556
สัญลักษณ์ของโฟลว์ชาร์ต
รูปข้างบนเป็นสัญลักษณ์ ที่ใช้ทำโฟลว์ชาร์ต เราจะเริ่มต้นการเขียนโฟลว์ชาร์ตด้วย สัญลักษณ์
สัญลักษณ์ เริ่มต้น ที่มันคล้ายๆกับวงรี(terminal) เอาไว้เริ่มปรแก รมกับจบโปรแกรมถ้าอยู่ใน ฟังก์ชันย่อย สัญลักษณ์วงรี(ขอเรียกแบบนี้ละกัน)ก็จะเป็นชื่อของฟังชันย่อย และ ถ้ามีการ คืนค่ากลับ ก็จะใช้สัญลักษณ์เดียวกันในการเขียนการคืนค่า ถ้าไม่คืนค่า ก็จะใส่ end"ในวงรีตอนจบโปรแกรม
สัญลักษณ์ การการนำเข้า/นำออกข้อมูล เอาใส่ตรงที่เอารับค่าจากผู้ใช้เข้ามาหรือพูดง่ายๆถ้าต้องการ input ก็ให้ใส่ และเอาไว้ใส่ตอนแแสดงข้อมูล ก็เวลาจะโชว์อะไร ก็ให้ใส่อันนี้เลย
สัญลักษณ์ การตัดสินใจ แยกย่อยได้ 2 แบบ
-วนทำจนกว่าจะเงื่อนไขจะเป็นเท็จ (loop)
อันที่ จะใส่เงื่อนไขให้ทำเมื่อ.......... เช่น ทำในขณที่ ตัวแปร i น้อยกว่า 10(ใช้ตัวแปร i เป็นตัววนรอบ) เมื่อทำได้ 1 รอบ ก็ต้องเพิ่มค่าให้กับตัวแปรที่ใช้วนรอบด้วย โดยจะใช้กับคำสั่งประเภท while for do while
-เลือกอย่างใดอย่างหนึ่ง (select)
ให้เลือกทำโดยมีเงื่อนไขบอกไว้ อันนี้จะแยกออกเป็นสองทางเลยและส่วนใหญ่จะไม่ต้องเพิ่มค่าให้ตัวแปรเหมือนกับ loop โดยจะใช้กับคำสั่งประเภท if else
สัญลักษณ์ ปฏิบัติงาน คือเวลาต้องการให้มันทำอะไรก็ใส่ไอ้นี้เลย คือถ้าไม่เข้าเงื่อนข้างบนใส่ไอ้หมดเลย ครับ
สัญลักษณ์ต่อจุด ก็ตรงตัวเลยครับ
ขอขอบคุณ http://krusunanta.net ที่มาของรูปภาพ
อัลกอริทึ่ม
อัลกอริทึ่ม เป็น ภาษาอักกฤษซึ่งภาษาไทยเรียกว่า ขั้นตอนวิธี ก่อนที่เราจะเขียนโปรแกรมเราก็ต้องคิดอัลกอริทึ่มก่อน ซึ่งอัลกอริทึ่มที่คิดนั้นจะเป็นการคิดว่าในโปรแกรมของเราจะทำอะไรบ้าง เริ่มตั่งแต่เริ่มโปรแกรมจนถึงจบโปรแกรม
หากเริ่มเขียนโปรแกรมใหม่ๆก็ควรซ้อมมือด้วยการฝึกคิดอัลกอริทึ่มก็พอ ยังไม่ต้องเขียนเป็นโปรแกรมออกมาก็ได้ รูปแบบที่ใช้เขียนอัลกอริทึ่มที่เราคิดออกมาจะมีอยู่ 2 แบบคือ
1.ทำในรูปของโฟล์วชาร์ต
2.ทำในรูปของคำสั่งเทียม
วันนี้เราจะมาดูอัลกอริทึ่มแบบง่ายๆกันนะครับ นั่นก็คือ อัลกอริทึ่มของการต้มมาม่า
หากเริ่มเขียนโปรแกรมใหม่ๆก็ควรซ้อมมือด้วยการฝึกคิดอัลกอริทึ่มก็พอ ยังไม่ต้องเขียนเป็นโปรแกรมออกมาก็ได้ รูปแบบที่ใช้เขียนอัลกอริทึ่มที่เราคิดออกมาจะมีอยู่ 2 แบบคือ
1.ทำในรูปของโฟล์วชาร์ต
2.ทำในรูปของคำสั่งเทียม
วันนี้เราจะมาดูอัลกอริทึ่มแบบง่ายๆกันนะครับ นั่นก็คือ อัลกอริทึ่มของการต้มมาม่า
รูป โฟล์วชาร์ตของการต้มมาม่า
ครับสำหรับการต้มมาม่าก็ไม่มีไรมากเลยครับ ซึ่งถ้าถามเด็กประถมบอกให้วิธีการต้มมาม่า(เด็กคงหัวเราะอีก โตเป็นควายเเล้วยังต้มมาม่าไม่เป็นอีกหรอ) เด็กก็คงบอกได้อย่างง่ายดาย แต่ถ้าลองเอามาเขียนเป็นโฟล์วชาร์ตนี้ซิ แรกๆผมตอนผมทำ ผมก็ตึบเลย รู้นะว่าต้มมาม่ามันง่าย ง่ายน้อยกว่าปลอกกล้วยเข้าปากนิดหนึ่ง แต่การที่จะเอามาเขียนในโฟล์วชาร์ตนีซิไปไม่เป็นเลยครับ กลับกลายเป็นเรื่องที่ยาก
ที่ยากไม่ใช่ว่าเรียงลำดับวิธีการทำไม่เป็นนะครับ แต่ไม่รู้ว่าจะเอาอะไรมาใส่ในโฟล์วชาร์ต ไอ้เราก็ไม่รู้ว่าสัญาลักษณ์เขาเอาไว้ใช้ทำอะไรบ้าง กลายเป็นแค่วิธีต้มมาม่าก็ทำไม่เป็น จากรูปข้างบนก็จะรู้เลยว่าโฟล์วชาร์ตของการต้มมาม่านั้นไม่ยากเลยครับ
และวันหลังผมจะหาสัญญาลักษณ์ของโฟล์วชาร์ต มาให้นะครับ
วันพุธที่ 31 กรกฎาคม พ.ศ. 2556
Algorithms
Exploring Algorithms*
Traveling Salesperson I: Brute Force, Greedy, and Heuristics
Introduction
Imagine you have the unfortunate job of traveling to 10 different towns in your area each month in order to deliver something important. Needless to say, you'd like to make this road trip as short as possible. Each town is a different distance away from your town and from each other town. How do you figure out a route that will minimize the distance traveled? You may recognize this as the famous Traveling Salesperson Problem (TSP).
SP is a very important NP-complete problem. It maps to many real-world problems making it one of the most thoroughly explored of the NP-complete problems. People need to solve this problem, despite the fact that there is no known polynomial solution for all instances. We will explore TSP in this module as a means for illustrating a host of different algorithms and approaches to solving problems. Just about everything has been tried with TSP!
How to Solve It?
One way to solve this problem (and any other NP-complete problem) is to enumerate all possible routes, of which there are 10! (3,628,800) for 10 towns, and then choose the shortest. This is a brute force algorithm. It would only take a couple seconds on a typical PC to compute all the possible routes and distances for 10 towns. And you would only need to do it once.
There are problems with brute force algorithms, however. One is combinatorial explosion: if we add one more town, the increase in the number of routes we need to compute increases by 1000%. If we go up to 20 towns, we could not possibly enumerate all the routes in our lifetime!
Which do you use in which situation? Here is a frequently-cited guideline: If the computing time is not too long and you only need to compute the solution once, brute force works fine. If the computing time is too long to do brute force and/or you need to compute the solution often, it makes sense to try and reduce the number of solutions that we need to process. This can be done with a greedy algorithm.
from gcu.googlecode.com/files/Exploring%20Algorithms.doc
Traveling Salesperson I: Brute Force, Greedy, and Heuristics
Introduction
Imagine you have the unfortunate job of traveling to 10 different towns in your area each month in order to deliver something important. Needless to say, you'd like to make this road trip as short as possible. Each town is a different distance away from your town and from each other town. How do you figure out a route that will minimize the distance traveled? You may recognize this as the famous Traveling Salesperson Problem (TSP).
SP is a very important NP-complete problem. It maps to many real-world problems making it one of the most thoroughly explored of the NP-complete problems. People need to solve this problem, despite the fact that there is no known polynomial solution for all instances. We will explore TSP in this module as a means for illustrating a host of different algorithms and approaches to solving problems. Just about everything has been tried with TSP!
How to Solve It?
One way to solve this problem (and any other NP-complete problem) is to enumerate all possible routes, of which there are 10! (3,628,800) for 10 towns, and then choose the shortest. This is a brute force algorithm. It would only take a couple seconds on a typical PC to compute all the possible routes and distances for 10 towns. And you would only need to do it once.
There are problems with brute force algorithms, however. One is combinatorial explosion: if we add one more town, the increase in the number of routes we need to compute increases by 1000%. If we go up to 20 towns, we could not possibly enumerate all the routes in our lifetime!
It is often possible to apply some clever techniques to reduce the number of enumerations that a brute force algorithm produces. Why not minimize the work involved if we can? Greedy algorithms sometimes provide a way to reduce the work involved with a brute force algorithm.
A greedy algorithm is one where we make the best choice at each stage of an algorithm given the immediate information available. These choices do not take into account all the data available from all stages of the algorithm. Sometimes the immediate information is enough and an optimal solution is found; sometimes it's not enough, and non-optimal solutions are found.
There is a simple greedy algorithm for solving TSP: Start at any city. From there, go to the closest unvisited city. Continue until you have visited all the cities, at which point you return to the starting city. In practice, this works fairly well, but it may or may not find an optimal solution.
Check out this resource for some other interesting examples. Then continue on in this resource through the discussion of greedy algorithms.
As shown in the counting change and knapsack examples, greedy algorithms are interesting alternatives to brute force algorithms. As mentioned earlier, the difficulty with greedy algorithms is there is no guarantee that you will find the optimal solution, whereas with brute force an optimal solution is guaranteed. Greedy algorithms are useful regardless, because they are usually easy to define and can provide good approximations of an optimal solution. More important, they significantly reduce the work involved.A greedy algorithm is one where we make the best choice at each stage of an algorithm given the immediate information available. These choices do not take into account all the data available from all stages of the algorithm. Sometimes the immediate information is enough and an optimal solution is found; sometimes it's not enough, and non-optimal solutions are found.
There is a simple greedy algorithm for solving TSP: Start at any city. From there, go to the closest unvisited city. Continue until you have visited all the cities, at which point you return to the starting city. In practice, this works fairly well, but it may or may not find an optimal solution.
Check out this resource for some other interesting examples. Then continue on in this resource through the discussion of greedy algorithms.
Which do you use in which situation? Here is a frequently-cited guideline: If the computing time is not too long and you only need to compute the solution once, brute force works fine. If the computing time is too long to do brute force and/or you need to compute the solution often, it makes sense to try and reduce the number of solutions that we need to process. This can be done with a greedy algorithm.
from gcu.googlecode.com/files/Exploring%20Algorithms.doc
สมัครสมาชิก:
บทความ (Atom)