当前位置:   article > 正文

西北工业大学2023C语言noj小白部分解答版_noj答案c

noj答案c

更新此篇更多是用作自己记录,展现小白真实成长过程,顺便给大家提供小白版noj解题代码()

感恩大佬指导!!

前几题略过了,可以去看大佬代码。

大佬代码可参见http://t.csdnimg.cn/mcBo7,还有其他大佬也在更,可以自己搜到,只与这位大佬有交流(已获授权),所以这里只提到这位佬。还可以去康康这位佬更新的noj易错总结https://annesede.github.io/p/nojc%E6%98%93%E9%94%99%E6%80%BB%E7%BB%93/

提醒:小白切记检查基础错误,比如用scanf有无&,{ }的位置,定义的数据类型与printf输出类型是否对应......一定要学调试!上手还挺简单的,目前我个人感觉来说,知道加断点,下一列,看窗口就ok。

8.计算地球上两点之间的距离

3dd4d7f930fd4e3b87beb4729a6ec7da.png

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include<math.h>
  4. const double p=3.1415926;
  5. double hav(double j)
  6. {
  7. return j=(1-cos(j))/2.0;
  8. }
  9. double hu(double jiao)
  10. {
  11. return jiao=jiao/180.0*p;
  12. }
  13. int main()
  14. {
  15. double w1,j1,w2,j2,y;
  16. scanf("%lf %lf",&w1,&j1);
  17. scanf("%lf %lf",&w2,&j2);
  18. w1=hu(w1);
  19. j1=hu(j1);
  20. w2=hu(w2);
  21. j2=hu(j2);
  22. y=hav(w2-w1)+cos(w1)*cos(w2)*hav(j2-j1);
  23. y=acos(1-2*y)*6371;
  24. printf("%.4lfkm",y);
  25. return 0;
  26. }

8.9.10.这三题知道定义函数,调用函数之类就OK。使用cos,pow等函数时头文件记得加math.h,cb对该错误不报错,提交noj会显示ce。

9.计算寒意指数

12d9a7253288475890078d9c9f03de3e.png

  1. #include <stdio.h>
  2. #include<math.h>
  3. int main()
  4. {
  5. double wc;
  6. double T,v;
  7. scanf("%lf %lf",&v,&T);
  8. wc=13.12+0.6215*T-11.37*pow(v,0.16)+0.3965*T*pow(v,0.16);
  9. printf("%.0lf",wc);
  10. }

这题要注意四舍五入,直接做类型转换会截断,可以像我这样用%.0lf解决,也可以用wc=(int)(wc+0.5)。

10.颜色模型转换
3989398fcbf740dd9735379e96caa51f.png
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. double max(double a,double b,double c)
  4. { double d;
  5. if(a>=b){
  6. if(a>=c)d=a;
  7. else d=c;
  8. }
  9. else{if(b>=c)d=b;
  10. else d=c;
  11. }
  12. return d;
  13. }
  14. double min(double a,double b,double c)
  15. { double d;
  16. if(a<=b){
  17. if(a<=c)d=a;
  18. else if(c<=b)d=c;
  19. }
  20. else{
  21. if(b<=c)d=b;
  22. else if(c<=a)d=c;
  23. }
  24. return d;
  25. }
  26. int main()
  27. {
  28. double R,G,B,H,S,V,v;
  29. scanf("%lf%lf%lf",&R,&G,&B);
  30. R/=255;
  31. G/=255;
  32. B/=255;
  33. V=max(R,G,B);
  34. if(V==0)S=0;
  35. else {
  36. v=min(R,G,B);
  37. S=(V-v)/V;
  38. }
  39. if(V==R)H=60*(G-B)/(V-v);
  40. if(V==G)H=60*(2+(B-R)/(V-v));
  41. if(V==B)H=60*(4+(R-G)/(V-v));
  42. if(H<0)H+=360;
  43. printf("%.4lf,%.4lf%%,%.4lf%%",H,S*100,V*100);
  44. return 0;
  45. }

这题一开始真...,根本没看懂字节值是啥......后来有大佬告诉我直接除以255就行,因为R,G,B取值范围是0-1,输入是0-255。

然后注意printf是怎样输出%的,要用%%。(第一个%会被判定为引导符,用于引导输出项的格式,只有一个%会被认为是没加输出类型,而不会打印% 。)(详可参见http://t.csdnimg.cn/5xELA)(已获授权)

11.级数和

  1. #include <stdio.h>
  2. #include <math.h>
  3. double a(int n)
  4. {
  5. double m,s;
  6. m=n+1;
  7. while(floor(m)){
  8. m/=10.0;
  9. }
  10. s=m+n;
  11. return s;
  12. }
  13. int main(){
  14. int n=1,k;
  15. double an,sum;
  16. scanf("%d",&k);
  17. while(n<k){
  18. an=a(n);
  19. printf("%g+",an);
  20. sum+=an;
  21. n+=1;
  22. }
  23. an=a(n);
  24. sum+=an;
  25. printf("%g=%g",an,sum);
  26. return 0;
  27. }

这题要知道floor函数(来源于math.h,所以用这个也要记得加头文件):向下取整,即取不大于x的最大整数,数学里的取整函数【x】。用floor函数实现小数部分的输出。

把输出放进while循环,用%g实现小数点后尾部0的截断,来成功输出。

12.对称数

这题有问题,应该是180°,不知道AC咋判的,我选择直接cv...

13.比率

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include<math.h>
  4. long long gys(long long a,long long b){
  5. if(b==0)return a;
  6. else return gys(b,a%b);
  7. }
  8. int cou(double x){
  9. int m=0;
  10. while(x!=floor(x)) {
  11. x*=10;
  12. m++;
  13. }
  14. return m;
  15. }
  16. int main()
  17. {
  18. double x;
  19. long long c,m,g,d;
  20. scanf("%lf",&x);
  21. m=cou(x);
  22. c=pow(10,m);
  23. g=fabs(gys(x*c,c));
  24. d=x*c/g;
  25. c/=g;
  26. printf("%lld/%lld",d,c);
  27. return 0;
  28. }

第一个难题就是怎么把任意小数化为整数,可以直接乘一个很大的数,比如1000000...,也可以用floor来解决(这玩意还挺好用,赞喔)。然后要知道用辗转相除法求最大公约数。

这题还要注意考虑负数,如果不用fabs,输入为负数,比如-4.2时,会输出21/-5(不过我也不知道不考虑会不会算AC...);但是数据范围是一定要考虑的,我一开始用int显示WA,改为long long才AC。

14.分数的加、减、乘、除

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. long long gcd(long long a,long long b)
  4. {
  5. if(b)return gcd(b,a%b);
  6. else return a;
  7. }
  8. int main()
  9. { long long a,b,c,d;
  10. scanf("%lld/%lld",&a,&b);
  11. scanf("%lld/%lld",&c,&d);
  12. printf("(%lld/%lld)+(%lld/%lld)=%lld/%lld\n",a,b,c,d,(a*d+b*c)/gcd(a*d+b*c,b*d),b*d/gcd(a*d+b*c,b*d));
  13. printf("(%lld/%lld)-(%lld/%lld)=%lld/%lld\n",a,b,c,d,(a*d-b*c)/gcd(a*d-b*c,b*d),b*d/gcd(a*d-b*c,b*d));
  14. printf("(%lld/%lld)*(%lld/%lld)=%lld/%lld\n",a,b,c,d,(a*c)/gcd(a*c,b*d),b*d/gcd(a*c,b*d));
  15. printf("(%lld/%lld)/(%lld/%lld)=%lld/%lld\n",a,b,c,d,(a*d)/gcd(a*d,b*c),b*c/gcd(a*d,b*c));
  16. }
15.操作数

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include<math.h>
  4. long long sum(long long x)
  5. { long long a,s=0;
  6. while(floor(x))
  7. {
  8. a=x%10;
  9. s+=a;
  10. x/=10;
  11. }
  12. return s;
  13. }
  14. int main()
  15. {
  16. long long x,n=0,count=1;
  17. scanf("%lld",&x);
  18. while(x-n)
  19. {
  20. n=sum(x);
  21. x-=n;
  22. count++;
  23. }
  24. printf("%lld",count);
  25. return 0;
  26. }

16.方阵

  1. #include <stdio.h>
  2. int main(){
  3. int n,m;
  4. scanf("%d",&n);
  5. for (int i = 0; i < n; ++i) {
  6. for (int j = 0; j < n; ++j) {
  7. m = (i-j) > 0 ? (i-j) : (j-i);
  8. printf("%d ",m);
  9. }
  10. printf("\n");
  11. }
  12. return 0;
  13. }

17.组合数

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. { int n,a,b,c,d,m=0,count=0;
  5. scanf("%d",&n);
  6. for(a=0;a<=9;++a){
  7. for(b=0;b<=9;++b){
  8. for(c=0;c<=9;++c){
  9. for(d=0;d<=9;++d){
  10. m=a+b+c+d;
  11. if(n==m)count++;
  12. }
  13. }
  14. }
  15. }
  16. printf("%d",count);
  17. return 0;
  18. }

18.乘数模

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. {
  5. long long a,b,m,c;
  6. scanf("%lld%lld%lld",&a,&b,&m);
  7. c=((a%m)*(b%m))%m;
  8. printf("%lld",c);
  9. return 0;
  10. }

我是先做完幂数模才做的乘数模(noj每章节出题顺序应该是随机的,对大佬应该没差,对我这种...so友情提示各位不会可以先往后面看几题,可能简单些),不知道这题要不要考虑溢出那些,保险还是用(a*b)mod m=(a mod m)*(b mod m)mod m吧。总数取模等于各因子取模的积取模。

19.幂数模

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include<math.h>
  4. int main()
  5. {
  6. unsigned long long a,b,c,d=1;
  7. scanf("%llu%llu%llu",&a,&b,&c);
  8. while(b!=0){
  9. if(b&1)d=(d*a)%c;
  10. a=(a*a)%c;
  11. b>>=1;
  12. }
  13. printf("%llu",d);
  14. return 0;
  15. }

要用快速幂模,去看b站即可,可以把快速幂一起看了,不懂没关系,先记住吧(还好考实验可以带纸质资料...)

20.倍数和

  1. # include <stdio.h>
  2. int sum(int b){
  3. int sum=0;
  4. for(int n=1;n<b;n++){
  5. if(n%3==0||n%5==0)sum+=n;
  6. }
  7. return sum;
  8. }
  9. int main(){
  10. int n,b,c,i=0;
  11. scanf("%d",&n);
  12. int s[n];
  13. c=n;
  14. while(c){
  15. scanf("%d",&b);
  16. s[i]=sum(b);
  17. i++;
  18. c--;
  19. }
  20. i=0;
  21. while(i+1<=n){
  22. printf("%d\n",s[i]);
  23. i++;
  24. }
  25. return 0;
  26. }

不得不说,你瓜noj真的很奇怪...这才第二十个题,明明章节标题还是循环,就得用到数组了(不过我也不知道有没有不用数组就能解决的方法...)。去看翁恺老师数组那几节就完事

21.好数字

  1. #include <stdio.h>
  2. #include<math.h>
  3. int main(){
  4. long long n,sum=1,m=pow(10,9)+7;
  5. scanf("%lld",&n);
  6. while(n){
  7. if(n%2!=0)sum=(5*sum)%m;
  8. else sum=(4*sum)%m;
  9. n--;
  10. }
  11. printf("%lld",sum%m);
  12. return 0;
  13. }

这题要注意C语言数数是从0开始数起的,比如4562,从左到右分别是第0位、第一位、第二位、第三位。所以长度为1的好数字总数实际就是看个位偶数有几个,0、2、4、6、8,五个,输出为5。

奇数位是4个素数,所以这题实质就是个累乘问题。N=1时,总数为5;N=2时,总数为5*4;N=3时,总数为5*4*5......而此题还要求取模,又要用到乘数模(见18题)。

(这里如果用宏定义m,#define m (pow(10,9)+7),pow是double型,m会被记成double型,取余运算错误。改成#define m 1000000007就行。)

22.竖式计算

这题略过,大佬代码感觉挺清楚的。(好吧其实是太麻烦我直接放弃...)

23.查找数列

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. { long long n,a;
  5. scanf("%lld",&n);
  6. for(a=1;n>a+1;a++)n-=a;
  7. printf("%lld",n);
  8. return 0;
  9. }

24.余数和

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. {
  5. long long k,n,i,sum=0;
  6. scanf("%lld%lld",&n,&k);
  7. for(i=1;i<=n;i++){
  8. sum+=k%i;
  9. }
  10. printf("%lld",sum);
  11. }

25.毕达哥拉斯三元组

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. { int a,b,c,n,f=0;
  5. scanf("%d",&n);
  6. for(a=1;a<=n;a++){
  7. for(b=a;b<=n;b++){
  8. c=n-a-b;
  9. if(c>b&&a*a+b*b==c*c){
  10. f=1;break;
  11. }
  12. }
  13. if(f==1)break;
  14. }
  15. printf("%d",a*b*c);
  16. return 0;
  17. }

学到了怎么控制嵌套for循环都break...

这题奇怪的在于用int给过,long long不行,unsigned long long又可以...这是为啥,有无大佬解答一下,感恩

26.俄罗斯农夫乘法

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int sum(int a,int b){
  4. int sum=0;
  5. if(a==0||b==0)return 0;
  6. if(a==1)return b;
  7. printf("%d %d\n",a,b);
  8. while(a!=1){
  9. if(a%2!=0)sum+=b;
  10. a/=2;b*=2;
  11. printf("%d %d\n",a,b);
  12. }
  13. sum+=b;
  14. return sum;
  15. }
  16. int main()
  17. {
  18. int a,b,s=0;
  19. scanf("%d%d",&a,&b);
  20. s=sum(a,b);
  21. printf("%d",s);
  22. return 0;
  23. }

这题是真奇怪+恶心啊,也没说清楚a=0时如何输出,测试发现a=0或者b=0时不打印a,b,直接输出sum才行,什么狗东西......

做题记得考虑特殊情况,a=0,a=1等等。

27.阶乘倍数

复杂...不懂...先行放弃。直接循环求阶乘去找会越界,但是只要加入考虑k是质数的时候N即为k的情况就AC了,不放代码了就(源cv...)。估计是样例里有个挺大的质数,但也仅限于此了。考试的时候尽己所能写得了...

28.方案数

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main()
  4. { long long n,cnt=0,i;
  5. scanf("%lld",&n);
  6. for(i=1;((i*i-i)/2)<n;i++){
  7. if((n-(i*i-i)/2)%i==0)cnt++;
  8. }
  9. printf("%lld",cnt);
  10. return 0;
  11. }

这题这位大佬讲的很清楚,不多说哩。http://t.csdnimg.cn/rVFNb(方便大家看,截了过来,也可以去看看大佬的其他题。)(已获授权)

29.最大数字

RE:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int m(int N){
  4. int a=0,b=0,c;
  5. for(c=N;c/10;c/=10){
  6. a=(c/10)%10;
  7. b=c%10;
  8. if(a>b)break;
  9. }
  10. if(a>b)return m(--N);
  11. else return N;
  12. }
  13. int main()
  14. { int N,n;
  15. scanf("%d",&N);
  16. n=m(N);
  17. printf("%d",n);
  18. return 0;
  19. }

老师帮忙改了下后的AC代码:

  1. #include <stdio.h>
  2. int maxNumber(int N)
  3. {
  4. int a=0,b=10,c,m;
  5. for(m=N; m>=0; m--)
  6. {
  7. b=10;
  8. for(c=m; c!=0; c/=10)
  9. {
  10. a=c%10;
  11. if(a>b)
  12. break;
  13. else
  14. b=a;
  15. }
  16. if(a<=b)
  17. return m;
  18. }
  19. return m;
  20. }
  21. int main()
  22. {
  23. int N,n;
  24. scanf("%d",&N);
  25. n=maxNumber(N);
  26. printf("%d",n);
  27. return 0;
  28. }

我的思路是从N开始检查,依次递减,直到检查到符合题意的数字。感觉没啥问题()但提交就是RE,老师说可能是因为我用的递归,测试样例中有非常大的数,导致递归层次很深,栈溢出了。把递归改成循环应该就不会溢出了。(关于栈,有学长说:机器在调用函数时程序会进入一个与主程序截然不同的环境运行,为了实现两个环境之间交互(返回值,参数)系统有一个自带的数据结构栈来存储这些数据,计算机里不存在无限这个概念,所以栈的大小也是固定的,当函数调用的次数比栈的大小大时,栈就溢出了。)

给出考试模拟题小白版解答,maybe可供突击用()

91.【IO】气体扩散
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <math.h>
  4. int main()
  5. {
  6. double m,n,a;
  7. scanf("%lf%lf",&m,&n);
  8. a=sqrt(n/m);
  9. printf("%.4lf",a);
  10. return 0;
  11. }
92.【递归】阿克曼数
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int A(int m,int n){
  4. if(m==0)return n+1;
  5. if(n==0)return A(m-1,1);
  6. else return A(m-1,A(m,n-1));
  7. }
  8. int main()
  9. {
  10. int m,n,c;
  11. scanf("%d%d",&m,&n);
  12. c=A(m,n);
  13. printf("%d",c);
  14. return 0;
  15. }
93.【循环】圆周率
  1. #include <stdio.h>
  2. double pai(long long n){
  3. double sum=3,a;
  4. while(n-1){
  5. a=4.0/((2*n-2)*(2*n-1)*(2*n));
  6. if(n%2==0)sum+=a;
  7. else sum-=a;
  8. --n;
  9. }
  10. return sum;
  11. }
  12. int main(){
  13. long long n;
  14. double sum;
  15. scanf("%lld",&n);
  16. sum=pai(n);
  17. printf("%.7lf",sum);
  18. return 0;
  19. }

前三题都是知道定义函数就行,挺简单的。

94.【数组】重复元素
  1. #include <stdio.h>
  2. int main(){
  3. int a[100007];
  4. int n,i,j,cnt=0;
  5. scanf("%d",&n);
  6. for(i=0;i<n;i++){
  7. scanf("%d",&a[i]);
  8. for(j=0;j<i;j++){
  9. if(a[i]==a[j]){
  10. cnt++;
  11. break;
  12. }
  13. }
  14. }
  15. printf("%d",cnt);
  16. return 0;
  17. }

这题我给出的代码思路就是每输入一个数据,都从a[0]开始与数组已有数据比较,找到相同的就cnt++,要注意找到一个后就要break,不然就会重复多记。比如1 3 1 1,没有break的话,输入第三个1时,cnt会+2而非+1。

95.【选择】马赫数
  1. #include <stdio.h>
  2. #include <math.h>
  3. double c(double t){
  4. return 331.3*sqrt(1+t/273.15);
  5. }
  6. int main(){
  7. double v,t,M;
  8. scanf("%lf%lf",&v,&t);
  9. M=(v/3.6)/c(t);
  10. if(M-0.8<1e-6)printf("%.3lf subsonic",M);
  11. else if(M-1.2<1e-6)printf("%.3lf transonic",M);
  12. else if(M-5.0<1e-6)printf("%.3lf supersonic",M);
  13. else printf("%.3lf hypersponic",M);
  14. return 0;
  15. }

这题也没啥好说的,就定义函数,然后用if就好了。

96.【字符串】左右操作
  1. #include <stdio.h>
  2. #include <string.h>
  3. int main(){
  4. char a[1000];
  5. int i,j,n,m;
  6. scanf("%s",a);
  7. n=strlen(a);
  8. for(i=0;i<(n/2);i++){
  9. for(j=0;j<(n/2-i);j++){
  10. if(a[j]<a[j+1]){
  11. char t;
  12. t=a[j];
  13. a[j]=a[j+1];
  14. a[j+1]=t;
  15. }
  16. }
  17. }
  18. if(n%2==0)m=n/2;
  19. else m=n/2+1;
  20. for(i=m,j=0;j<n/4;i++,j++){
  21. char t;
  22. t=a[i];
  23. a[i]=a[n-j-1];
  24. a[n-j-1]=t;
  25. }
  26. printf("%s",a);
  27. return 0;
  28. }

这题首先要知道字符串的输入输出。注意用%s输入字符串不需要&,直接用数组名。

我的思路很直接,就左右两边分开处理,左边用的冒泡排序,右边对调。

97.【算法】零钞

  1. #include <stdio.h>
  2. int main()
  3. {
  4. int n,a,b,c,d;
  5. scanf("%d",&n);
  6. a=n/10;
  7. b=(n-a*10)/5;
  8. c=(n-a*10-b*5)/2;
  9. d=n-a*10-b*5-c*2;
  10. if(d)printf("1=%d\n",d);
  11. if(c)printf("2=%d\n",c);
  12. if(b)printf("5=%d\n",b);
  13. if(a)printf("10=%d\n",a);
  14. return 0;
  15. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/545364
推荐阅读
相关标签
  

闽ICP备14008679号