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

2024-03-24 13:20

本文主要是介绍西北工业大学2023C语言noj小白部分解答版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更新此篇更多是用作自己记录,展现小白真实成长过程,顺便给大家提供小白版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

#include <stdio.h>
#include <stdlib.h>
#include<math.h>const double p=3.1415926;
double hav(double j)
{return j=(1-cos(j))/2.0;
}
double hu(double jiao)
{return jiao=jiao/180.0*p;
}
int main()
{double w1,j1,w2,j2,y;scanf("%lf %lf",&w1,&j1);scanf("%lf %lf",&w2,&j2);w1=hu(w1);j1=hu(j1);w2=hu(w2);j2=hu(j2);y=hav(w2-w1)+cos(w1)*cos(w2)*hav(j2-j1);y=acos(1-2*y)*6371;printf("%.4lfkm",y);return 0;
}

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

9.计算寒意指数

12d9a7253288475890078d9c9f03de3e.png

#include <stdio.h>
#include<math.h>int main()
{double wc;double T,v;scanf("%lf %lf",&v,&T);wc=13.12+0.6215*T-11.37*pow(v,0.16)+0.3965*T*pow(v,0.16);printf("%.0lf",wc);
}

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

10.颜色模型转换
3989398fcbf740dd9735379e96caa51f.png
#include <stdio.h>
#include <stdlib.h>double max(double a,double b,double c)
{   double d;if(a>=b){if(a>=c)d=a;else d=c;}else{if(b>=c)d=b;else d=c;}return d;
}
double min(double a,double b,double c)
{   double d;if(a<=b){if(a<=c)d=a;else if(c<=b)d=c;}else{if(b<=c)d=b;else if(c<=a)d=c;}return d;
}
int main()
{double R,G,B,H,S,V,v;scanf("%lf%lf%lf",&R,&G,&B);R/=255;G/=255;B/=255;V=max(R,G,B);if(V==0)S=0;else {v=min(R,G,B);S=(V-v)/V;}if(V==R)H=60*(G-B)/(V-v);if(V==G)H=60*(2+(B-R)/(V-v));if(V==B)H=60*(4+(R-G)/(V-v));if(H<0)H+=360;printf("%.4lf,%.4lf%%,%.4lf%%",H,S*100,V*100);return 0;
}

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

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

11.级数和

#include <stdio.h>
#include <math.h>double a(int n)
{double m,s;m=n+1;while(floor(m)){m/=10.0;}s=m+n;return s;
}
int main(){int n=1,k;double an,sum;scanf("%d",&k);while(n<k){an=a(n);printf("%g+",an);sum+=an;n+=1;}an=a(n);sum+=an;printf("%g=%g",an,sum);return 0;
}

这题要知道floor函数(来源于math.h,所以用这个也要记得加头文件):向下取整,即取不大于x的最大整数,数学里的取整函数【x】。用floor函数实现小数部分的输出。(本人一开始想着要判断小数位数去了,想着这也太麻烦了,知道floor后:原来是用这种方式解决的吗,斯国以内)

把输出放进while循环,用%g实现小数点后尾部0的截断,来成功输出。(是的,本小白最开始连这题咋输出都不知道...)

12.对称数

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

13.比率

#include <stdio.h>
#include <stdlib.h>
#include<math.h>long long gys(long long a,long long b){if(b==0)return a;else return gys(b,a%b);
}int cou(double x){int m=0;while(x!=floor(x)) {x*=10;m++;}return m;
}int main()
{double x;long long c,m,g,d;scanf("%lf",&x);m=cou(x);c=pow(10,m);g=fabs(gys(x*c,c));d=x*c/g;c/=g;printf("%lld/%lld",d,c);return 0;
}

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

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

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

#include <stdio.h>
#include <stdlib.h>long long gcd(long long a,long long b)
{if(b)return gcd(b,a%b);else return a;
}
int main()
{   long long a,b,c,d;scanf("%lld/%lld",&a,&b);scanf("%lld/%lld",&c,&d);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));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));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));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));
}
15.操作数

#include <stdio.h>
#include <stdlib.h>
#include<math.h>long long sum(long long x)
{   long long a,s=0;while(floor(x)){a=x%10;s+=a;x/=10;}return s;
}
int main()
{long long x,n=0,count=1;scanf("%lld",&x);while(x-n){n=sum(x);x-=n;count++;}printf("%lld",count);return 0;
}

16.方阵

#include <stdio.h>int main(){int n,m;scanf("%d",&n);for (int i = 0; i < n; ++i) {for (int j = 0; j < n; ++j) {m = (i-j) > 0 ? (i-j) : (j-i);printf("%d ",m);}printf("\n");}return 0;
}

17.组合数

#include <stdio.h>
#include <stdlib.h>int main()
{   int n,a,b,c,d,m=0,count=0;scanf("%d",&n);for(a=0;a<=9;++a){for(b=0;b<=9;++b){for(c=0;c<=9;++c){for(d=0;d<=9;++d){m=a+b+c+d;if(n==m)count++;}}}}printf("%d",count);return 0;
}

18.乘数模

#include <stdio.h>
#include <stdlib.h>int main()
{long long a,b,m,c;scanf("%lld%lld%lld",&a,&b,&m);c=((a%m)*(b%m))%m;printf("%lld",c);return 0;
}

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

19.幂数模

#include <stdio.h>
#include <stdlib.h>
#include<math.h>int main()
{unsigned long long a,b,c,d=1;scanf("%llu%llu%llu",&a,&b,&c);while(b!=0){if(b&1)d=(d*a)%c;a=(a*a)%c;b>>=1;}printf("%llu",d);return 0;
}

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

20.倍数和

# include <stdio.h>int sum(int b){int sum=0;for(int n=1;n<b;n++){if(n%3==0||n%5==0)sum+=n;}return sum;
}int main(){int n,b,c,i=0;scanf("%d",&n);int s[n];c=n;while(c){scanf("%d",&b);s[i]=sum(b);i++;c--;}i=0;while(i+1<=n){printf("%d\n",s[i]);i++;}return 0;
}

不得不说,你瓜noj真的很奇怪...这才第二十个题,明明章节标题还是循环,就得用到数组了(不过我也不知道有没有不用数组就能解决的方法...)。去看翁恺老师数组那几节就完事(顺带一提,这应该是本人第一个算得上独立解决且一次AC的题,夸夸!)

21.好数字

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

这题要注意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.查找数列

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

24.余数和

#include <stdio.h>
#include <stdlib.h>int main()
{long long k,n,i,sum=0;scanf("%lld%lld",&n,&k);for(i=1;i<=n;i++){sum+=k%i;}printf("%lld",sum);
}

25.毕达哥拉斯三元组

#include <stdio.h>
#include <stdlib.h>int main()
{   int a,b,c,n,f=0;scanf("%d",&n);for(a=1;a<=n;a++){for(b=a;b<=n;b++){c=n-a-b;if(c>b&&a*a+b*b==c*c){f=1;break;}}if(f==1)break;}printf("%d",a*b*c);return 0;
}

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

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

26.俄罗斯农夫乘法

#include <stdio.h>
#include <stdlib.h>int sum(int a,int b){int sum=0;if(a==0||b==0)return 0;if(a==1)return b;printf("%d %d\n",a,b);while(a!=1){if(a%2!=0)sum+=b;a/=2;b*=2;printf("%d %d\n",a,b);}sum+=b;return sum;
}
int main()
{int a,b,s=0;scanf("%d%d",&a,&b);s=sum(a,b);printf("%d",s);return 0;
}

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

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

27.阶乘倍数

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

(本来想着质因数分解,定义俩数组c1[i]c2[i],从n=2开始循环,分别把k的质因数和n!的质因数存入数组,只要k的每个质因数数目都小于等于n!相应质因数数目,就找出了最小n,但改了半天就是不对...以后再来试试)

28.方案数

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

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

29.最大数字

RE:

#include <stdio.h>
#include <stdlib.h>int m(int N){int a=0,b=0,c;for(c=N;c/10;c/=10){a=(c/10)%10;b=c%10;if(a>b)break;}if(a>b)return m(--N);else return N;
}
int main()
{   int N,n;scanf("%d",&N);n=m(N);printf("%d",n);return 0;
}

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

#include <stdio.h>int maxNumber(int N)
{int a=0,b=10,c,m;for(m=N; m>=0; m--){b=10;for(c=m; c!=0; c/=10){a=c%10;if(a>b)break;elseb=a;}if(a<=b)return m;}return m;
}int main()
{int N,n;scanf("%d",&N);n=maxNumber(N);printf("%d",n);return 0;
}

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

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

由于noj问题,以下还在评阅,并不保证AC。

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

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

94.【数组】重复元素
#include <stdio.h>int main(){int a[100007];int n,i,j,cnt=0;scanf("%d",&n);for(i=0;i<n;i++){scanf("%d",&a[i]);for(j=0;j<i;j++){if(a[i]==a[j]){cnt++;break;}}}printf("%d",cnt);return 0;
}

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

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

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

96.【字符串】左右操作
#include <stdio.h>
#include <string.h>
int main(){char a[1000];int i,j,n,m;scanf("%s",a);n=strlen(a);for(i=0;i<(n/2);i++){for(j=0;j<(n/2-i);j++){if(a[j]<a[j+1]){char t;t=a[j];a[j]=a[j+1];a[j+1]=t;}}}if(n%2==0)m=n/2;else m=n/2+1;for(i=m,j=0;j<n/4;i++,j++){char t;t=a[i];a[i]=a[n-j-1];a[n-j-1]=t;}printf("%s",a);return 0;
}

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

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

97.【算法】零钞

#include <stdio.h>int main()
{int n,a,b,c,d;scanf("%d",&n);a=n/10;b=(n-a*10)/5;c=(n-a*10-b*5)/2;d=n-a*10-b*5-c*2;if(d)printf("1=%d\n",d);if(c)printf("2=%d\n",c);if(b)printf("5=%d\n",b);if(a)printf("10=%d\n",a);return 0;
}

这篇关于西北工业大学2023C语言noj小白部分解答版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/841701

相关文章

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上