Реферат: Computer Languages Essay Research Paper Despite having
Название: Computer Languages Essay Research Paper Despite having Раздел: Топики по английскому языку Тип: реферат |
Computer Languages Essay, Research Paper Despite having very little knowledge of the world of computer programming, I have come to believe that C++ is currently the programming language of choice. If that is the case, it would be easiest to only learn C++ and to ignore the other programming languages. However, computer programmers should not ignore the other programming languages for at least three important reasons. One, some computers might not accept C++ as a programming language. Two, there may be features of other programming languages that are superior to C++. Three, there are many useful programs written in languages besides C++ that can only be modified with knowledge of those other languages. For these reasons, it is important that all good programmers are able to adapt to other programming languages. The intention of this lab is to create computer programmers who are able to adapt to many different programming languages. Section I: Examining High-Level Programming Languages Introduction to Section I In this section, six previously-prepared programs, written in the programming languages Fortran, Pascal, and C, are looked at and compared. For each program a hypothesis is formed about the function the program serves, and the way in which the program performs that function. Also included in the hypothesis is a description of what makes the programming language easy or difficult to read. Testing the hypothesis is simply a matter of compiling and running the program using a variety of inputs. For each experiment in this section, I wrote out a hypothesis for the program before I tested it. Then, after testing the program, I prepared a conclusion about how the program works. Experiment 1: oddeven.f Hypothesis I believe that the Fortran program will first ask for how many numbers are in your list of numbers. Then it will read in all the numbers in your list, one at a time and tell you if the number that you just entered is even or odd. The program will keep track of how many of your numbers are even and how many are add. After you have entered in all the numbers in your list, it will print out how many of your numbers are odd and how many are even. The Fortran language is fairly easy to understand, so forming my hypothesis of what the program would do was not a very difficult task. Most of the commands used in Fortran are words that represent their function like "PRINT *," "READ *," "IF," "THEN," and "END." On the other hand, Some of the commands used, like "DO 11 I =1" and "MOD," are vague and not easily understood. The print commands are especially helpful for checking my hypothesis. Because the print commands were written to give the user a good idea of what the program is doing, they also helped me figure out what the program is going to do. Conclusion The program behaved pretty much as I thought it would in my hypothesis. First the program instructed me to "Enter length of list." Then I was to enter in the numbers in my list one by one, and after each number the computer either responded with "[number] is even" or "[number] is odd. After I had entered in all the numbers in my list, the program printed out how many of my numbers were even and how many were odd. The program did not even mess up when I entered in decimal numbers, instead it just truncated the number and proceeded as if the truncated number was the number to be evaluated. Unfortunately, the program did label zero an even number, which it isn’t, but that is a fairly minor mistake. Also, I happened to have noticed that if I was entering numbers, and screwed up, the program wouldn’t let me delete the last number I entered. This is kind of a drawback, but I don’t know how one would go about fixing that problem. Experiment 2: weather.p Hypothesis To begin with, the program will print the following "Good day. My name is Ronald Gollum. I’m stuck in this box until quitting time. Please chat with me about the weather. Is it raining now?" The computer will store the user’s answer to this question under a variable titled "Ans." If your answer to the question is Y or y, then the computer will store the value true under the Boolean variable titled "Raining." If your answer to that question is not Y or y, then the program will store the value False in "Raining" and then print the message "Too bad. We need rain." No matter what was entered previously, the program will print the message "Do you think it will rain tomorrow?" The program will replace the old value of "Ans" with the answer to this new question. If the answer is Y or y the program will print "I’ll worry about that tomorrow." If the value stored under "Raining" is true, the computer will then print the message "It’s finally quitting time! Good bye. You brightened up this rainy day." Otherwise, the program will write, "It’s finally quitting time! Good bye. I want to work on my tan." For Pascal, like for Fortran, most of the commands are words that represent something – commands like "begin," "writeln" (I am guessing that ln stands for line), "readln," "if," "then," and "end." In Pascal, though, the commands that store and interpret variables are not worded as I would expect them to be. For example, one command was "if not Raining then [?]". I would expect a computer to have an easier time with a more defined command like "if raining = false then [?]." That Pascal command was probably someone’s attempt to make the program more like plain English. I also noticed that the words in Pascal are not capitalized like in Fortran. In general, Pascal appears to be much more like normal paragraph then Fortran. Tests Input Ouput at end Input Immediate Output Y You brightened up this? Y I’ll worry about that tomorrow. yes You brightened up this? YES I’ll worry about that tomorrow N I want to work on my tan. N none No I want to work on my tan. NO none Yahoo You brightened up this? YOyO I’ll worry about that tomorrow Hallo I want to work on my tan. Ween none 1999 I want to work on my tan. /?? none Conclusion The program ran pretty much like I said that it would in my hypothesis. The only real difference is that the program reacts to any word beginning with a Y or a y, like it is a Y or a y. That is because only the first letter of any word that is entered in is stored. When I entered the word yummy, the computer treated it like I had entered an affirmative y. In the same respect, when I entered the completely unrelated word Odd as a response, the computer treated my answer like a negative response, and later responded like I had said no. I tried answering with a bunch of different responses including numbers, symbols, and even Pascal commands, but in every case the computer treated my answer like a negative response, unless my response began with a Y or a y. Experiment 3: triangle.c Hypothesis The program will ask for three side lengths for a triangle. If all three side lengths are equal, the program will print "Equilateral\n". If two side lengths are equal, the program will print "Isosceles\n". Otherwise, the program will print "Scalene\n". The program will repeat until 0 is entered as a side length, and then it will stop. Trying to guess what this program is going to do was really difficult. This program is much longer than the first two, and many of the commands seem to be unnecessary (commands like "#include", "int clasify," "break," and "scanf"). The commands are very difficult to read, and involve complex syntax (What the heck is the command "scanf ("%If%If", "&s2", &s3)" supposed to do?). The only reason that I have any idea what the program is going to do is because of the print statements, which print what the user needs to know. However, even within the quotation marks of the print statements there is C syntax, like in this command "printf ("Isosceles/n")". The if commands, at the end of the program, led me to believe that the computer just compares the lengths to see whether or not they are equal to each other. Tests Inputs Output 13, 13, 13 Equilateral 12, 16, 12 Isosceles 100, 90, 1 Scalene 45.8, 57.3, 45.8 Isosceles -99, -99, -99 Equilateral Inputs Output -18, -96, 5, -18 Isosceles -56, -56, 38 Isosceles -89, 89, 98 Scalene -9, -9.5, 9.5 Scalene -11.25, -11.25, -11.25 Equilateral Inputs Output 76000, 7600.1,7600.1 Isosceles 8600.1, 8600.2, 8600.3 Scalene 17, 0 , 89 (ends) 0, 89, 123 (ends) -119, 245, 0 (ends) Conclusion Surprisingly, my hypothesis was fairly close to being right. The computer instructed me to enter three lengths. After I entered three lengths the computer told me what kind of triangle those lengths corresponded to (scalene, isosceles, or equilateral). The program did not print isosceles/n etc? like I hypothesized it would, instead it printed isosceles. When I entered zero as a side length the program ended just like it was supposed to.. The program would accept negative lengths, despite the fact that a negative length is not possible. The only stipulation the program had to separate the 3 different kinds of triangles is that the correct number of side lengths was equal. Experiment 4: Language Comparison Before Running the Programs C is a very difficult programming language to understand. C commands are full of syntax that does not seem to represent the plain English equivalent of the commands. C also requires all sorts of symbols, parentheses, and brackets, which makes the program look cluttered and cryptic. The bright side to the symbols, parentheses, and brackets is that the programmer does not have to follow any specific format. Compared to the C program, the Fortran program is very easy to read. Fortran reads almost like a normal language algorithm. The commands used are REAL, PRINT *, READ *, and END. The programmer still needs to know some syntax, but not nearly as much as C. Each line contains one complete command, and nothing else. There are no brackets, and parentheses cluttering up the program. Pascal is very similar to Fortran, except that it is a little bit more complex and cluttered. Each line in Pascal has a semicolon at the end, whereas Fortran did not need those semicolons. Pascal also has colons and parentheses within the commands that Fortran does not have. Pascal is still much easier to read than C. After Running the Programs When I ran them, the three programs were almost identical. The only difference between the three programs was the way the final print was formatted. Pascal represented the numbers in scientific notation with 8 decimal places, while Fortran and C represented the numbers in standard notation with about 6 decimal places. Fortran also had large spaces before and after each number, whereas C did not. adda.f Adds 3 Numbers instead of 2. PROGRAM ADD 3 REAL NUM1, NUM2, NUM3, SUM PRINT *, ‘Enter three numbers: ‘ READ *, NUM1, NUM2, NUM3 SUM = NUM1 + NUM2 + NUM3 PRINT * PRINT *, ‘The sum of ‘, NUM1, ‘, ‘, NUM2, ‘ and ‘, NUM3, ‘is ‘, SUM PRINT * END All I needed to do to modify the program was add a third number to the declaration, to the initial "PRINT" command, to the "READ" command, to the "SUM =" statement, and to the final "PRINT" command. addb.f subtracts two numbers PROGRAM SUBTRACT REAL NUM1, NUM2, SUB PRINT *, ‘Enter two numbers: ‘ READ *, NUM1, NUM2 SUB = NUM1 – NUM2 PRINT * PRINT *, NUM1, ‘ minus ‘, NUM2, ‘ is ‘, SUB PRINT * END All I needed to do to modify this program was to change the SUM variable to SUB, change the addition sign in the "SUB =" statement to a subtract sign, and change the final printout to print the appropriate statement. addc.f Divides two numbers PROGRAM MULTIPLY OR DIVIDE REAL NUM1, NUM2, PROD PRINT *, ‘Enter two numbers: ‘ READ *, NUM1, NUM2 PROD = NUM1 / NUM2 PRINT * PRINT *, NUM1, ‘ / ‘, NUM2, ‘ is ‘, PROD PRINT * END All I needed to do to modify this program was to change the SUM variable to PROD, change the addition sign in the "SUM =" statement to a division symbol, and change the final printout to print the appropriate statement. Conclusion to Section I Writing the hypothesis’s for each the three programs turned out to be more difficult than I would have thought. Each program had it’s own syntax, and figuring out the syntax was not an easy task. In experiment four, I decided that Fortran was the easiest language to understand, Pascal was the next easiest, and C was extremely difficult to understand. Without looking at the print statements for C, I would not have been able to figure out what the triangle program did at all. Minimizing the syntax and making the commands represent their functions is extremely important for producing a readable, programmable language. Section II: Programming In C++ Introduction to Section II For the last week in class, we have been working exclusively with C++ without using computers, so I have been looking forward to seeing the programs I’ve written in action. After programming in assembly language, the prospect of writing programs that will write out lines of characters that actually mean something is thrilling to me. I have heard that programming in C++ is a pain in the butt, but I can not imagine that it is nearly has laborious as programming in assembly language. In the section, I will find out if I can cut it as a C++ programmer. Experiment 5: taxes.cc Hypothesis First the program reads in your taxable income. If your taxable income is less than $20,000 a year, the program multiplies your taxable income by the low-rate tax (15%), and that value is your tax. If your taxable income is less than $50,000 and greater than or equal to $20,000, the program multiplies your taxable income by the mid-rate tax (28%), and that value is your tax. If your taxable income is greater than or equal to $50,000, the program multiplies your taxable income by the high-rate tax (.31), and that value is your tax. Finally, the program prints your tax. Because we have been studying C++ for the last week, understanding this program was not very difficult at all. If it were not for that experience, this would probably be one of the more difficult programs to read. The program uses quiet a bit of syntax, and the parentheses, brackets, and symbols make it look cluttered and unorganized. On the good side, the program has all the constants and variables at the beginning were they can be easily changed. Conclusion The program worked as I thought it would in my hypothesis for all positive numbers. For 0, the program returned zero, and for negative numbers, the program returned the corresponding negative answers. Experiment 6: determine_grade.cc The Algorithm Get a value for minimum satisfactory score. Get a value for student’s score. If student’s score is greater than or equal to minimum satisfactory score then Print the message "Student’s score is satisfactory." Else (student’s score is less than minimum satisfactory score) Print the message "Student’s score is unsatisfactory." Stop. The Source Code // Program: Determine Grade // Author: Nathan Lindquist // Date Written: November 3, 1999 // Purpose of Program: To read in a minimum satisfactory score and a // student’s score, and determine if the student’s score is satisfactory // or unsatisfactory, based on the minimum satisfactory score. // #include *iostream.h* int main () { double min_satisfact_score; double student_score; cout ** endl ** "Enter the lowest satisfactory score." ** endl; cin ** min_satisfact_score; cout ** endl ** "Enter the student’s score." ** endl; cin ** student_score; if (student_score *= min_satisfact_score) { cout ** endl ** "Student’s score of " ** student_score; cout ** " is satisfactory." ** endl ** endl; } else { cout ** endl ** "Student’s score of " ** student_score; cout ** " is unsatisfactory." ** endl ** endl; } } Experiment 7: Modifying A C++ Program The Algorithm Get a value for points scored. If the value of points scored is greater than or equal to 90, Print the message "This vegetable is Grade A Fancy." Else if the value of points scored is greater than or equal to 84, Print the message "This vegetable is Extra Standard." Else if the value of points scored is greater than or equal to 10, Print the message "This vegetable is Standard." Else, Print the message "This vegetable is Substandard." Stop. The Source Code // Name of Program: Determine Veggie Class // Author: Nathan Lindquist // Date written: November 3, 1999 // Purpose of Program: To read in the point value of a U S Department // of Agriculture graded canned vegetable and decide which class (Grade A // Fancy, Extra Standard, Standard, or Substandard) that canned vegetable // fits into. // #include *iostream.h* int main () { int point_score; cout ** endl ** "Enter the USDA point score of a canned vegetable " ** endl; cout ** "(the score should be an integer.)" ** endl; cin ** point_score; if (point_score *= 90) { cout ** endl ** "This vegetable is Grade A Fancy" ** endl; } else if (point_score *=85) { cout ** endl ** "This vegetable is Extra Standard" ** endl; } else if (point_score *=70) { cout ** endl ** "This vegetable is Standard" ** endl; } else { cout ** endl ** "This vegetable is Substandard" ** endl; } } Tests Input Output 105 This veg. is Grade A Fancy 93 This veg. is Grade A Fancy 90 This veg. is grade A Fancy 87 This veg. is Extra Standard 85 This veg. is Extra Standard Input Output 76 This veg. is Standard 70 This veg. is Standard 65 This veg. is Substandard 0 This veg. is Substandard -13 This veg. is Substandard Experiment 8: Comparing C++ And Assembly Language The Algorithm The values of Integer and Total are 0. While Integer is not equal to -1 Get a new value for Integer. Set the value of Total equal to the previous value of Total + Integer. Print the value of Total. The Source Code // Name of Program: Add Until // Author: Nathan Lindquist // Date Written: November 3, 1999 // Purpose of program: To read in integers and add them // until an end number (-1) is entered. When the end // number (-1) is entered the program ends. // #include *iostream.h* int main() { const int EndNumber= -1; // When this integer is entered, the total // is printed, and the program ends. int Integer; int Total; Integer = 0; Total = 0; while (Integer != EndNumber) // This will do the following steps until // the end numver is entered. { Total = Total + Integer; cout ** endl ** "Enter an integer to be added. Enter the integer " ** endl; cout ** EndNumber ** " to print the total and end this program."** endl; // These two cout commands tell the user to "Enter an // integer to be added. Enter the integer [EndNumber] // to print the total and end this program." cin ** Integer; } cout ** endl ** "The total of all the integers you " ** endl; cout ** "entered, except for the "; cout ** EndNumber ** ", is " ** Total ** "." ** endl ** endl; // These final three cout commands print "The total of // all the integers you entered, except for the // [EndNumber] is [Total]. } Tests Inputs Manual Calculations Output 3, 30, 10, 7, 18, -1 3 + 30 +10 + 7 + 18 = 68 68 -15, -20, -40, -7, -1 -15 + -20 + -40 + -7 = -82 -82 7, 0, 31, -128, -15, 75 -1 7 + 0 + 31 + -26 + -15 = -3 -30 127, -36, 15, -118, 0, 43, 49, 18, -1 126 + -36 + 15 + -118 + 0 + 43 + 49 + 18 =97 98 Conclusion While the above C++ program is actually longer than my assembly language program from last lab, the C++ program above is ten times better. The C++ program actually tells the user what value to enter and what the output means. Whereas as in assembly language, a user would not know what to input or what the output means. In the above program the constant that ends the program can be easily switched from -1 to some other number; in assembly language, switching a constant like that could take an hour. In the above program, changing the program from adding numbers, to multiplying them would be a matter of changing one sign; in assembly language, such a change quadruples plus the size of your program. Conclusion to Section II Compiling the C++ programs actually worked out fairly well for me. If my program had an error in it when I tried to compile it, the computer would tell me what line the error was on, and it would point to what it thought the error was. Fortunately, I did not end up with any serious problems, most of my mistakes were just typos. I heard that many others where having a very difficult time compiling their C++ programs. Compared to assembly language, programming in C++ is no problem. Conclusion Programming in Fortran, Pascal, and C++ is much more productive then programming in assembly language. A whole array of much more advanced tools is at our disposal. Now, we can write whole lines of characters, label variables and constants, use Boolean expressions with variables and numbers other than zero, write comments into the program, and the list of new tools goes on, and on. Each one of these tools by itself would take hours, if not days to write an efficient assembly language program for. In high level programming language, we don’t have to worry about registers, memory, storage, retrieval, and other assembly language functions. To write a program that instructs the user what to enter, inputs the side lengths of a triangle, and outputs the kind of triangle it is, would take weeks of boring, meticulous assembly language programming. With Pascal, Fortran, and C++, the same program takes an hour or less. |