zoukankan      html  css  js  c++  java
  • C++高级语言程序设计实验四-中国矿业大学

    第一题

    题目描述

    (1)定义两个一维数组x,y,不超过50个元素。
    (2)从键盘输入k个整数到数组x中。
    (3)计算x中数据的平均值ave及大于平均值的元素个数n并输出。
    (4)将数组x中数据复制到数组y中,重复的数据只存储一次,最后输出y中的数据。
    输入:输入两行,第一行为输入的数据个数,第二行若干整数,每个整数后面有一个空格用于分隔;
    输出:第一行若干整数,每个整数后面有一个空格,最后一个空格后换行;第二行若干整数,每个整数后面有一个空格,最后一个空格后不需要换行;

    源代码

    #include<iostream>
    using namespace std;
    int list1[50], list2[50];
    float ave=0;
    int sum=0;
    int more=0;
    int main()
    {
        int n=0;
        cin>>n;
        for (int i=0; i<n; i++)
    {
            int temp;
            cin>>temp;
            list1[i]=temp;
            sum+=temp;
        }
        ave=1.0*sum/n;
        cout<<ave<<" ";
        for (int j=0; j<n; j++)
    {
            if (list1[j]>ave)
    {
                more++;
            }
        }
        cout<<more<<endl;
        for (int p1=0,p2=0; p1<n; p1++,p2++)
    {
            bool flag=1;
            for (int k=0; k<p1; k++)
    {
                if (list1[p1]==list1[k])
    {
                flag=0;
                break;
                }
            }
            if (flag)
    {
                list2[p2]=list1[p1];
                cout<<list2[p2]<<" ";
            }
        }
    }
    

    运行结果

    第二题

    题目描述

    有12人围坐成一圈玩报数游戏,从1号人员开始顺时针报数,报到k的人员被淘汰出局;接着仍沿顺时针方向从被淘汰出局者的下一人员又重新从1 开始报数,报到k的人被淘汰;如此继续,直到最后只剩下一个人时停止。请编写程序输出最后所剩那个人的编号。
    注意:(1)假设参加游戏的人的编号沿顺时针方向依次为1到12,可以使用数组来存放各数据;
    (2)k>1,由用户通过cin输入指定。输入一个整数,代表报数值;
    输出一个整数,即最后剩下的人的编号;

    源代码

    #include<iostream>
    using namespace std;
    int main()
    {
        int s[12];
        int i,j,k;
        for (i=1;i<=12;i++)
        {
            s[i]=i;
        }
        cin >> k;
        int n=12;
        int start=1;
        while (n > 1)
        {
            j=k+start-1;
            while (j >= n) j=j % n;
            if (j == 0) j=n;
            start=j;
            for (i=start+1;i<=12;i++)
                s[i-1]=s[i];
            n--;
        }
        cout << s[1] << endl;
        return 0;
    }
    

    运行截图

    第三题

    题目描述

    小宗想知道两个日期之间所间隔的天数,他希望有一个日期计算器,输入两个日期后能够自动计算之间的天数。要求:设计相应的函数完成天数的计算,在主函数中验证正确性。
    输入:按照年月日的顺序输入两个日期,年月日之间用一个空格分隔;
    输出:输出两个日期之间的天数,即一个整数,整数后不需要换行;

    源代码

    #include<iostream>
    using namespace std;
    int m[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
    bool isLeapYear(int year)
    {
        return ((year%4==0 && year%100!=0) || year%400==0);
    }
    int getDays(int year, int month, int day)
    {
        if(isLeapYear(year))
            m[1]++;
        int sum = 0;
        for(int i = 1;i < year;i++)
        {
            sum += 365;
            if(isLeapYear(i))
                sum ++;
        }
        for(int i = 1;i < month;i++)
        {
            sum += m[i-1];
        }
        sum += day;
        return sum;
    }
    int dayDis (int y1, int m1, int d1,
                int y2, int m2, int d2)
    {
        return getDays(y2, m2, d2) - getDays(y1, m1, d1);
    }
         
    int main(void)
    {
        int y1,m1,d1;
        int y2,m2,d2;
        cin>>y1>>m1>>d1>>y2>>m2>>d2;
        cout<<dayDis(y1,m1,d1,y2,m2,d2);
        return 0;
    } 
    

    运行截图

    第四题

    题目描述

    对于整型数组a[10]和b[10],编制程序完成下列任务:
    (1)由用户从键盘为两个数组输入值;
    (2)求出两个数组的最大值和最小值;
    (3)把数组a和b中的整数分别从小到大和从大到小排序;
    (4)把两个有序的数组a和b组成一个长度为20的有序数组c[20],使数组c的顺序为从小到大。
    输入:两行整数,每行10个,第一行是数组a里的数组,第二行是数组b里的数值;
    输出:五行,第一行有两个整数,分别是数组a的最大值和最小值,两个整数之间用一个空格分隔;第二行有两个整数,分别是数组b的最大值和最小值,两个整数之间用一个空格分隔;第三行按照从小到大的顺序输出数组a里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第四行按照从大到小的顺序输出数组b里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第五行按照从小到大的顺序输出合并后数组c里的数值,每个数字后面有一个空格,最后一个数字后面也有空格。

    源代码

    #include<iostream>
    using namespace std;
    int a[10];
    int b[10];
    int c[20];
    int max(int n[])
    {
        int M=n[0];
        for (int i=0; i<10; i++)
        {
            if (n[i]>M) M=n[i];
        }
        return M;
    }
    int min(int n[])
    {
        int m=n[0];
        for (int i=0; i<10; i++)
        {
            if (n[i]<m) m=n[i];
        }
        return m;
    }
    void sort(int n[])
    {
        for (int i=0; i<9; i++)
        {
            for (int j=0; j<9; j++)
            {
                if (n[j]>n[j+1])
                {
                int temp=n[j];
                n[j]=n[j+1];
                n[j+1]=temp;
                }
            }
        }
    }
    void mix(int m[], int n[])
    {
        int p1=0;
        int p2=0;
        int p3=0;
        while(p1<=9 && p2<=9)
        {
            if (m[p1]<n[p2])
            {
                c[p3]=m[p1];
                p1++; p3++;
            }
            else
            {
                c[p3]=n[p2];
                p2++; p3++;
            }
        }
        if (p1==10)
        {
            for (; p3<20; p2++, p3++) c[p3]=n[p2];
        }
        else
        {
            for (; p3<20; p1++, p3++) c[p3]=m[p1];
        }
    }
    int main()
    {
        for (int i=0; i<10; i++) cin>>a[i];
        for (int i=0; i<10; i++) cin>>b[i];
        cout<<max(a)<<" "<<min(a)<<endl;
        cout<<max(b)<<" "<<min(b)<<endl;
        sort(a);
        for (int i=0; i<10; i++) cout<<a[i]<<" ";
        cout<<endl;
        sort(b);
        for (int i=9; i>=0; i--) cout<<b[i]<<" ";
        cout<<endl;
        mix(a,b);
        for (int i=0; i<20; i++) cout<<c[i]<<" ";
        cout<<endl;
    }
    

    运行截图

    第五题

    题目描述

    利用cin.getline()函数从键盘录入一句英文,其中每个单词之间用一个空格隔开,最后用'.'结束。统计该句话中单词的个数,并依次输出每个单词。输出个数后换行,输出每个单词后也换行。注意:在本平台下,cin.getline()函数的使用方式如下:
    char s[50];
    cin.getline(s,50); //最多存储49个字符
    输入一句英文,其中每个单词之间用一个空格隔开,最后一个单词后面用英文的'.'作为结束;输出每个单词后换行,最后一行输出单词的数量。

    源代码

    #include<iostream>
    using namespace std;
    int main()
    {
       int i,num=0;
       char s[50];
       cin.getline(s,50);
       while(1)
       {
           if(s[i]!=' ' &&s[i]!='.')
           cout<<s[i];
           else
           {
               num++;
               cout<<endl;
            }
            if(s[i]=='.')
        break;
        i++;
    	}
    	cout<<num;
    }
    

    运行截图

  • 相关阅读:
    java语言基础--标识符、关键字
    #考研碎碎念#3
    #考研笔记#计算机之word问题
    #考研#计算机文化知识1(局域网及网络互联)
    #学习笔记#jsp
    #学习笔记#JSP数据交互
    考研随笔2
    考研随笔1
    几个人
    全局变量
  • 原文地址:https://www.cnblogs.com/hujunyao37201/p/14123251.html
Copyright © 2011-2022 走看看