zoukankan      html  css  js  c++  java
  • PTA第三次上机

    5-1

    #include <iostream>
    #include <cstdlib>
    #include <string.h>
    using namespace std;
    
    class polygon
    { 
        protected: 
            int number;
        private:
        	int side_length[100];
        public:
        	polygon(int a = 0):number(a){memset(side_length, 0, sizeof(side_length));};
            int perimeter();//计算多边形边长
            void display();//输出多边形边数和周长
            int* reachsidelen();
    };
    
    int polygon::perimeter()
    {
    	int i;
    	int tot = 0;
    	for (i = 1; i <= number; i++)
    	{
    		tot += side_length[i];
    	}
    	
    	return tot;
    }
    
    void polygon::display()
    {
    	cout << number << " " << perimeter() << endl;
    }
    
    int* polygon::reachsidelen()
    {
    	return side_length;
    }
    
    class rectangle : protected polygon
    {
    	protected:
    	int height;
            int width;
        public:
        	rectangle(int a = 0, int b = 0, int c = 0):polygon(a), height(b), width(c){};
        	int perimeter();//计算矩形边长
            void display();//输出多边形边数和周长
    };
    
    int rectangle::perimeter()
    {
    	int tot = 0;
    	tot = height * 2 + width * 2;
    	return tot;
    }
    
    void rectangle::display()
    {
    	cout << number << " " << perimeter() << endl;
    }
    
    class equal_polygon : protected polygon
    {
    	protected:
    	int side_len;
    	public:
    	equal_polygon(int a = 0, int b = 0):polygon(a), side_len(b){};
    	int perimeter();//计算等边多边形边长
            void display();//输出多边形边数和周长
    };
    
    int equal_polygon::perimeter()
    {
    	int tot = 0;
    	tot = number * side_len;
    	return tot;
    }
    
    void equal_polygon::display()
    {
    	cout << number << " " << perimeter() << endl;
    }
    
    int main()
    {
    	int b[105];
    	int i,j;
    	
    	int cnt = 0;
    	cin >> cnt;
    	
    	int ope;
    	while(cnt --)
    	{
    		memset(b, 0, sizeof(b));
    		
    		cin >> ope;
    		if(ope == 0)
    		{
    			int tot = 1;
    			int idata;
    			while(cin >> idata)
    			{
    				if(idata == -1)break;
    				
    				b[tot++] = idata;
    			}
    			tot --;
    			
    			polygon P(tot);
    			int *p = P.reachsidelen();
    			
    			for (i = 1; i <= tot; i++)
    			{
    				*(p + i) = b[i];
    			}
    			
    			P.display();
    		}
    		else if(ope == 1)
    		{
    			int iwide, ilen;
    			cin >> iwide >> ilen;
    			rectangle R(4, ilen, iwide);
    			R.display();
    		}
    		else if(ope == 2)
    		{
    			int inumber, ilen;
    			cin >> inumber >> ilen;
    			equal_polygon E(inumber, ilen);
    			E.display();
    		}
    	}
    	
    	return 0;
    }
    

    5-2

    #include <iostream>
    #include <stdlib.h>
    #include <cmath>
    using namespace std;
    
    class Point_1D
    { 
    protected:
        float x;//1D 点的x坐标
    public:
        Point_1D(float a = 0): x(a){};
    
        float distance( );//计算当前点到原点的距离
    };
    
    float Point_1D::distance()
    {
    	float d = x;
    	if(d < 0) d = -d;
    	return d;
    }
    
    class Point_2D : protected Point_1D
    {
    	protected:
    	    float y;
    	public:
    		Point_2D(float a = 0, float b = 0): Point_1D(a), y(b){};
    		float distance( );
    };
    
    float Point_2D::distance()
    {
    	float d;
    	d = sqrt(x * x + y * y);
    	return d;
    }
    
    class Point_3D : protected Point_2D
    {
    	protected:
    		float z;
    	public:
    		Point_3D(float a = 0, float b = 0, float c = 0): Point_2D(a, b), z(c){};
    		float distance( );
    };
    
    float Point_3D::distance()
    {
    	float d;
    	d = sqrt(x * x + y * y + z * z);
    	return d;
    }
    
    int main()
    {
    	int ope;
    	while(cin >> ope)
    	{
    		if(ope == 0)break;
    		if(ope == 1)
    		{
    			float ix;
    			cin >> ix;
    			Point_1D p1(ix);
    			
    			cout << "Distance from Point " << ix << " to original point is " 
    			<< p1.distance() << endl;
    		}
    		else if(ope == 2)
    		{
    			float ix, iy;
    			cin >> ix >> iy;
    			Point_2D p2(ix, iy);
    			
    			cout << "Distance from Point(" << ix << "," << iy 
    			<< ") to original point is " << p2.distance() << endl;;
    		}
    		else if(ope == 3)
    		{
    			float ix, iy, iz;
    			cin >> ix >> iy >> iz;
    			Point_3D p3(ix, iy, iz);
    			
    			cout << "Distance from Point(" << ix << "," << iy << "," << iz
    			<< ") to original point is " << p3.distance() << endl;;
    		}
    	}
    	return 0;
    }
    

    5-3

    用了sstream,主函数太长了。。

    #include <iostream>
    #include <cstdlib>
    #include <sstream>
    using namespace std;
    
    class Date
    {
    	protected:
    		int year;
            int month;
            int day;
        public:
        	Date(int a = 0, int b = 0, int c = 0):year(a), month(b), day(c){};
    };
    
    class Time
    {
    	protected:
    		int hour;
            int minute;
            int second;
        public:
        	Time(int a = 0, int b = 0, int c = 0):hour(a), minute(b), second(c){};
    };
    
    class Schedule : protected Date, protected Time
    {
    	protected:
    	    int ID;
    	public:
    		Schedule(int y = 10000, int m = 0, int d = 0, int h = 0, int min = 0, int s = 0, int id = 0):
    		Date(y, m, d), Time(h, min, s), ID(id){};
    		
    		bool operator < (const Schedule & s2);
    		
    		void display();
    };
    
    void Schedule::display() //The urgent schedule is No.1: 2014/6/27 8:0:1
    {
    	cout << ID << ": " << year << "/" << month << "/" << day << " " << hour 
    	<< ":" << minute << ":" << second << endl;
    }
    
    bool Schedule::operator < (const Schedule & s2)
    {
    	int dtot1 = 0, tot1 = 0;
    	int dtot2 = 0, tot2 = 0;
    	dtot1 = year * 365 + month * 30 + day;
    	dtot2 = s2.year * 365 + s2.month * 30 + s2.day;
    	
    	tot1 = hour * 3600 + minute * 60 + second;
    	tot2 = s2.hour * 3600 + s2.minute * 60 + s2.second;
    	
    	if(dtot1 < dtot2)return true;
    	else if(dtot1 > dtot2)return false;
    	else
    	{
    		if(tot1 < tot2)return true;
    		else return false;
    	}
    }
    
    int main()
    {
    	int id;
    	int i;
    	int record;
    	Schedule sch;
    	
    	while(cin >> id)
    	{
    		if(id == 0)break;
    		
    		string date, time;
    		cin >> date >> time;
    		
    		stringstream stream;
    		string s1, s2;
    		
    		int y = 0, m = 0, d = 0, h = 0, min = 0, s = 0;
    		bool flag = false;
    		for(i = 0; i < date.length(); i++)
    		{
    			if(date[i] == '/')
    			{
    				if(flag)
    				{
    					stream << s1;
    					stream >> m;
    					stream.clear();
    					s1 = "";
    				}
    				else
    				{
    					stream << s1;
    					stream >> y;
    					stream.clear();
    					
    					s1 = "";
    					flag = true;
    				}
    			}
    			else 
    			s1 += date[i];
    		}
    		stream << s1;
    		stream >> d;
    		stream.clear();
    		
    		bool flag2 = false;
    		
    		for(i = 0; i < time.length(); i++)
    		{
    			if(time[i] == ':')
    			{
    				if(flag2)
    				{
    					stream << s2;
    					stream >> min;
    					stream.clear();
    					s2 = "";
    				}
    				else
    				{
    					stream << s2;
    					stream >> h;
    					stream.clear();
    					s2 = "";
    					
    					flag2 = true;
    				}
    			}
    			else 
    			s2 += time[i];
    		}
    		stream << s2;
    		stream >> s;
    		stream.clear();
    		
    		Schedule sch1(y, m, d, h, min, s, id);
    		if(sch1 < sch)sch = sch1;
    	}
    	
    	cout << "The urgent schedule is No.";
    	sch.display();
    	return 0;
    }
    
  • 相关阅读:
    Python 从零学起(纯基础) 笔记 之 collection系列
    ARM学习 之 如何在向内核写入系统调用
    idea的git使用案例
    idea使用git的pull命令报错1
    String、StringBuilder以及StringBuffer
    HashMap实现原理及源码分析
    logback使用注意点1
    创建zookeeper集群
    disconf安装问题
    linux更换jdk版本
  • 原文地址:https://www.cnblogs.com/qq952693358/p/5592284.html
Copyright © 2011-2022 走看看