zoukankan      html  css  js  c++  java
  • C语言第二次博客作业---分支结构

    一、PTA实验作业

    题目1:计算分段函数[2]

    本题目要求计算下列分段函数f(x)的值:

    1.实验代码

    double x,y;
    	
    	scanf ("%lf",&x);
    	if (x>=0){
    	
    		y= pow (x,0.5);
    	}
    	else{
    		y= pow (x+1,2)+2*x+pow (x,-1);
    	} 
    	printf("f(%.2f) = %.2f",x,y);
    

    2 设计思路

    • (1)定义两个变量x,y输入x的值
    • (2)判断x是否大于等于0若是则计算y= pow (x,0.5),否则计算y= pow (x+1,2)+2*x+pow (x,-1)
    • (3)输出y的值

    3.本题调试过程碰到问题及解决办法

    • (1)在输出时没注意到要输出的是f(10.00) = 3.16从而错输出f(x) = 3.16,后重新检查解决

    4.本题PTA提交列表

    题目2:输出三角形面积和周长

    本题要求编写程序,根据输入的三角形的三条边a、b、c,计算并输出面积和周长。注意:在一个三角形中, 任意两边之和大于第三边。三角形面积计算公式:area=√​s(s−a)(s−b)(s−c),其中s=(a+b+c)/2。

    1.实验代码

    int a,b,c;
    	double area,perimeter,s; 
    	
    	scanf("%d%d%d",&a,&b,&c);
    	if ((a+b>c)&&(a+c>b)&&(b+c>a)){
    		s=(a+b+c)/2;
    		area=sqrt (s*(s-a)*(s-b)*(s-c));
    		 perimeter = a+b+c;
    		printf("area = %.2f; perimeter = %.2f",area,perimeter);
    	}
    	else {
    		printf("These sides do not correspond to a valid triangle");
    

    2 设计思路

    • (1)定义abc为三边,area为面积,perimeter为周长,s海伦公式中周长一半
    • (2)判断是否满足任意两边之和大于第三边如果满足则计算s=(a+b+c)/2;area=sqrt (s(s-a)(s-b)*(s-c));perimeter = a+b+c;不满足则输出These sides do not correspond to a valid triangle

    3.本题调试过程碰到问题及解决办法

    • (1)刚开始>号写为>=导致答案一直错误后来经过再三检查才解决

    4.本题PTA提交列表

    题目3:出租车计价

    本题要求根据某城市普通出租车收费标准编写程序进行车费计算。具体标准如下:
    起步里程为3公里,起步费10元;
    超起步里程后10公里内,每公里2元;
    超过10公里以上的部分加收50%的回空补贴费,即每公里3元;
    营运过程中,因路阻及乘客要求临时停车的,按每5分钟2元计收(不足5分钟则不收费)。

    1.实验代码

        double distance;  
        int minute;  
        double fare = 0;  
        scanf("%lf%d", &distance, &minute);  
        if(minute >= 5)  
            fare = (minute / 5) * 2;  
        if(distance <= 3) {  
            fare += 10;       
        }  
        else if(distance <= 13) {  
            if(distance - 10 > 0)  
                fare += 10 + 7 * 2 + (distance - 10) * 3;  
            else  
                fare += 10 + (distance - 3) * 2;  
        }  
        else {  
            fare += 10 + 7 * 2 + (distance - 10) * 3;  
        }  
        printf("%d
    ", (int)(fare + 0.5));  
    

    2 设计思路

    • (1)定义distance为路程,fare为价格并赋予初始值为0,minute为停的时间输入路程和时间
    • (2)判断时间是否超过5分钟,是则计算fare = (minute / 5) * 2;再判断路程所在区间进行相应运算
    • (3)最后输出

    3.本题调试过程碰到问题及解决办法

    • (1)刚开始用if语句判断路程和停车的时间用了好多句if没有用else if并且判断过程中还复杂频繁答案出错,后经过询问同学得知了先判断停车时间在来判断距离不易出错后重新改写编程才成功

    4.本题PTA提交列表

    题目4:程序设计联考

    自从湖南农业大学、吉首大学和怀化学院组织程序设计课程联考以后,举办联考的经验越来丰富。尤其是在使用PTA系统作为考试平台之后,联考工作得到了很多学校的认可和支持。所以,现在参与联考的学校比较多。为了便于区分考生,考生账号的第一位是学校代号。1代表Hunan Agricultural University,2代表Jishou University,3代表Huaihua University,4代表Aerospace University,5代表Ocean University。 请编写程序根据考生的账号区分考生的学校。

    1.实验代码

    int number,x;
    	
    	scanf("%d",&number);
    	x=number/100000;
    	switch (x){
    		case 1:
    			printf("Hunan Agricultural University");
    			break;
    		case 2:
    			printf("Jishou University");
    			break;
    		case 3:
    			printf("Huaihua University");
    			break;
    		case 4:
    			printf("Aerospace University");
    			break;
    		case 5:
    			printf("Ocean University");
    			break;
    		default:
    			printf("Other University");
    			break;
    

    2 设计思路

    • (1)定义number为输入的学号,x为另一变量,输入number的值
    • (2)将number除100000去得学号的首位数字
    • (3)用switch语句判断首位数的值并输出相应学校

    3.本题调试过程碰到问题及解决办法

    • (1)刚开始用了if语句并用区间的形式来判断所输入的学号的范围,这种方式虽可行但有些麻烦,后来才知道要用switch语句并得知较为简单的办法来判断就是判断首位数字,然后重新编辑了自己的程序

    4.本题PTA提交列表

    二、截图本周题目集的PTA最后排名。

    三、本周学习总结

    1.你学会了什么?

    • (1)学会了switch语法和if语句及if语句的嵌套,知道了一些判断的小技巧
    • (2)知道了%m.nf的含义以及用它来进行结果的优化

    2.本周的内容,你还不会什么?

    • (1)不知道连续用if和if-else以及switch之间的区别以及好和坏的地方
    • (2)感觉自己的编程思维不够看到题目不能很好的想到便捷的算法

    3.你碰到什么困难,打算如何解决?

    • (1)在编程上思维有欠缺,有时候看到题目不能很好的处理变量,以及判断变量
    • (2)在编程过程中经常马虎把&漏写或写pta时需要空格忽略导致出错,每次检查时都要浪费一些时间感到十分无力
    • (3)在写pta时速度太慢,时间的分配非常不合理
    • (4)在接下来的时间里要勤写代码锻炼思维,加强自主学习能力,以及多向大牛请教
  • 相关阅读:
    fullCalendar改造计划之带农历节气节假日的万年历(转)
    Linked List Cycle
    Remove Nth Node From End of List
    Binary Tree Inorder Traversal
    Unique Binary Search Trees
    Binary Tree Level Order Traversal
    Binary Tree Level Order Traversal II
    Plus One
    Remove Duplicates from Sorted List
    Merge Two Sorted Lists
  • 原文地址:https://www.cnblogs.com/FOXES/p/7729136.html
Copyright © 2011-2022 走看看