2023年湖北省专升本C语言程序设计大题真题(湖北警官学院)

        今年的湖北省专升本考试已经在5月7日结束了,有许多学弟学妹想看看今年的考题究竟难不难,学长找到知情朋友打听了一些题目,为大家每期分享一题。

        题目:

        找出数组的最大值及其下标。(这一道题来自湖北省一所公办院校)我们一起来看看这道题如何解。

        假设数组元素为:23,12,9,88,67,101,66,10,90,34

#include<stdio.h>
int main(){
    int max(int,int);   //函数声明,其他函数写在主函数的下面则需要在主函数的开头对其进行声明,因为C语言是自上而下顺序执行的
                        //函数声明并不在乎形参变量名是什么,它只在乎形参的类型,因此声明的时候可以不注明形参名。

    int arr[] = {23,12,9,88,67,101,66,10,90,34};

    //计算这个数组有多少个元素
    int len = sizeof(arr)/sizeof(int);
    int temp = 0;   //用来存储两者中较大的那个值
    int tag = 0;    //用来记录最大值的数组下标
    for(int i=0;i<len;i++){     //用for循环遍历数组每一个元素

        temp = max(arr[i],temp);    //调用max函数用来比较两者之中较大的那一个数,并把较大的那个数重新赋值给变量temp
                                    //下一次比较时就是数组中下一个数和上一次比较结束后的较大的那个数了

        if(temp == arr[i]){     //用if条件语句来控制,因为只有当temp的值发生变化时,才说明程序找到了一个更大的数
                                //而这个变化是可以通过比较temp和当前下标的元素值是否相等来判断的,因此如果temp发生了变化
                                //就修改变量tag的值,记录当前最大值数组元素的下标
            tag = i;
        }
    }

    printf("最大的数是:%d,其下标为:%d",temp,tag);
    return 0;
}

int max(int x,int y){   //函数定义,他有两个形参都是int类型
    int num;    //用来作为返回值返回两者中最大的那个数
    if(x != y){     //先判断一下这两个数是不是相等,如果相等,其实际上让num等于哪一个都可以,这里我们让他等于第一个
        num = x > y ? x : y;    //三元表达式,就是如果x>y那么num就等于x,否则num就等于y
    }else num = x;  
    return num;     //将num最为返回值返回
}

【程序1】 题目:有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数都是多少 1.程序分析:可填在百位,十位,个位的数字都是1,2,3,4.组成所有的排列后再去 掉不满足条件的排列. 2.程序源代码: main() { int i,j,k; printf("\n"); for(i=1;i<5;i++) /*以下为三重循环*/ for(j=1;j<5;j++) for (k=1;k<5;k++) { if (i!=k&&i!=j&&j!=k) /*确保i,j,k三位互不相同*/ printf("%d,%d,%d\n",i,j,k); } } ============================================================== 【程序2】 题目:企业发放的奖金根据利润提成.利润(i)低于或等于10万元时,奖金可提10%;利润高 于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提 成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于 40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于 100万元时,超过100万元的部分按1%提成,从键盘输入当月利润i,求应发放奖金总数 1.程序分析:请利用数轴来分界,定位.注意定义时需把奖金定义成长整型. 2.程序源代码: main() { long int i; int bonus1,bonus2,bonus4,bonus6,bonus10,bonus; scanf("%ld",&i); bonus1=100000*0.1;bonus2=bonus1+100000*0.75; bonus4=bonus2+200000*0.5; bonus6=bonus4+200000*0.3; bonus10=bonus6+400000*0.15; if(i<=100000) bonus=i*0.1; else if(i<=200000) bonus=bonus1+(i-100000)*0.075; else if(i<=400000) bonus=bonus2+(i-200000)*0.05; else if(i<=600000) bonus=bonus4+(i-400000)*0.03; else if(i<=1000000) bonus=bonus6+(i-600000)*0.015; else bonus=bonus10+(i-1000000)*0.01; printf("bonus=%d",bonus); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值