解题基础:
scanf("输入模式",地址列表);//输入语句及其格式。注:地址列表一定要加取地址符号&,如:&a,&b
printf("输出模式",输出列表);//输出语句及其格式。注:输出模式和输出列表一一对应,如:printf("%d%d",a,b);
switch(表达式){
case 常量值1:
若干语句1
break;//可省略
case 常量值2:
若干语句2
break;//可省略
......
case 常量值n:
若干语句n
break;//可省略
default://可省略
若干语句
}//开关语句及其格式,若表达式的值等于某个常量值,则进行某常量值相对应的语句,若没遇到break,则接着运行下一个常量值后面的语句,直到遇到break为止,若表达式的值不等于某个常量值,则执行default后面的若干语句,default可省略(不执行语句)
思路:因为题目要求,需要一个输入的值和一个输出的值,因为定义a的是一个整型变量int,所以a/100000的值也是一个int型变量(整数)(注:C语言的取整不是四舍五入,是直接舍去小数),直接用switch函数可以写出运算语句(当然if也行,不过比较麻烦),t=对应区间的全部数*相应利润+(a-区间最大数)*超出相应的利润
答案:
#include<stdio.h> int main(){ int a,t; scanf("%d",&a); switch(a/100000){ case 0: t=a*0.1; break; case 1: t=100000*0.1+(a-100000)*0.075; break; case 2: case 3: t=100000*0.1+100000*0.075+(a-200000)*0.05; break; case 4: case 5: t=100000*0.1+100000*0.075+200000*0.05+(a-400000)*0.03; case 6: case 7: case 8: case 9: t=100000*0.1+100000*0.075+200000*0.05+200000*0.03+(a-600000)*0.015; default: t=100000*0.1+100000*0.075+200000*0.05+200000*0.03+400000*0.015+(a-1000000)*0.01; } printf("%d",t); return 0; }
ps:当a/100000=2时,因为常量值后面的若干语句中没有break,则接着运行下一个常量值(case 3)后面的若干语句,直到遇到break为止
同理,后面的4,6,7,8都是一样的
程序结束return 0;不可省。
因为题目表达原因,生活中t应该为浮点型常量,保留两位小数,可是答案不给对,所以代码就以答案为准
若对switch函数还有疑问,可以对应我的上一个题解题解1008:C语言程序设计教程(第三版)课后习题5.6 (C语言描述)参照学习
0.0分
54 人评分
#include <stdio.h> int main(void) { int I; //利润 int ward; scanf("%d",&I); if(100000>=I) ward=I*0.1; if(100000<I&&I<=200000) ward=10000+(I-10000)*0.075; else if(200000<I&&I<=400000) ward=10000+100000*0.075+(I-200000)*0.05; else if(400000<I&&I<=600000) ward=10000+100000*0.075+200000*0.05+(I-400000)*0.03; else if(600000<I&&I<=1000000) ward=10000+100000*0.075+200000*0.05+200000*0.03+(I-600000)*0.015; else if(I>1000000) ward=10000+100000*0.075+200000*0.05+200000*0.03+400
踏上星辰 2020-07-11 11:08:44 |
000*0.0015+(I-1000000)*0.01; printf("%d",ward); return 0; }
#include <stdio.h> int main() { int I; int reward =0; scanf("%d",&I); int n =I; double a[6]={0.10,0.075,0.05,0.03,0.015,0.01}; int b[6]={0,100000,200000,400000,600000,1000000}; int i=0,j=0; while(n>b[j+1]-b[j]){ reward += (b[j+1]-b[j])*a[j]; n = I-b[j+1]; j ++; if(j==5) break; } reward +=n*a[j]; printf("%d\n",reward); return 0; }
#include <stdio.h> int main() { int I; int reward =0; scanf("%d",&I); int n =I; double a[6]={0.10,0.075,0.05,0.03,0.015,0.01}; int b[6]={0,100000,200000,400000,600000,1000000}; int i=0,j=0; while(n>b[j+1]-b[j]){ reward += (b[j+1]-b[j])*a[j]; n = I-b[j+1]; j ++; if(j==5) break; } reward +=n*a[j]; printf("%d\n",reward); return 0; }
让你到最后一小时 2020-10-28 15:27:33 |
好厉害
#include<stdio.h> int main() { int a; int exact=0; int q=100000,w=200000,e=400000,r=600000,t=1000000; scanf("%d",&a); if(a>t) { exact =(a-t)*0.01+(t-r)*0.015+(r-e)*0.03+(e-w)*0.05+(w-q)*0.075+q*0.1; printf("%d",exact); } else if(a>r&&a<=t) { exact =(a-r)*0.15+(r-e)*0.03+(e-w)*0.05+(w-q)*0.075+q*0.1; printf("%d",exact); } else if(a>e&&a<=r) { exact =(a-e)*0.03+(e-w)*0.05+(w-q)*0.075+q*0.1; printf("%d",exact); } else if(a>w&&a<=e) { exact =(a-w)*0.05+(w-q)*0.075+q*0.1; printf("%d",exact); }
#include<stdio.h> #define P 100000 int main() { float i; scanf("%f",&i); if(i<0.0) printf("输入不合法"); else if (i<P) printf("%f",i*0.1); else if(i>=P&&i<2*P) printf("%f",P*0.1+(i-P)*0.075); else if(i>=2*P&&i<4*P) printf("%f",P*0.1+P*0.075+(i-P)*0.05); else if(i>=P*4&&i<6*P) printf("%f",P*0.1+P*0.075+2*P*0.05+(i-P)*0.03); else if(i>=6*P&&i<10*P) printf("%f",P*0.1+P*0.075+2*P*0.05+2*P*0.03+(i-6*P)*0.015); else printf("%f",P*0.1+P*0.075+2*P*0.05+2*P*0.03+4*P*0.015+(i-10*P)*0.01); return 0; }
#include<stdio.h> int main() { int a,b,c,d,e,f,z; scanf("%d",&z); a=z/10 ; b=100000/10+(z-100000)*0.075; c=(z-200000)*0.05+100000/10+100000*0.075; d=100000/10+100000*0.075+200000*0.05+(z-400000)*0.03; e=100000/10+100000*0.075+200000*0.05+200000*0.03+(z-600000)*0.015; f=100000/10+100000*0.075+200000*0.05+200000*0.03+400000*0.015+(z-1000000)*0.01; if(z<=100000) { printf("%d\n",a); }else if(z>100000&&z<=200000) { printf("%d\n",b); } else if(z>200000&&z<=400000) { printf("%d\n",c); } else if(z>400000&&z<=600000) { printf("%d\n",d); } else if(z>600000&&z<=1000000) { print
C2020 2020-05-22 12:24:23 |
不太符合一个出口
seahorizon 2020-07-16 18:21:03 |
哦,看错了