网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
输出样例:
153
代码:
#include<stdio.h>
#include<math.h>
int main()
{
int n;
scanf("%d",&n);
int i;
//if(n!=0){
long long sum=0;
for(i=1;i<=n;i++)
{
sum+=fun(i);
}
printf("%lld\n",sum);
//}
return 0;
}
int fun(int n)
{
int i;
long long t=1;
for(i=1;i<=n;i++)
{
t=t*i;
}
// printf("t=%lld\n",t);
return t;
}
21、练习3-2 计算符号函数的值
对于任一整数n,符号函数sign(n)的定义如下:
请编写程序计算该函数对任一输入整数的值。
输入格式:
输入在一行中给出整数n。
输出格式:
在一行中按照格式“sign(n) = 函数值”输出该整数n对应的函数值。
输入样例1:
10
输出样例1:
sign(10) = 1
输入样例2:
0
输出样例2:
sign(0) = 0
输入样例3:
-98
输出样例3:
sign(-98) = -1
代码:
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
if(n>=0)
{
if(n>0) printf("sign(%d) = 1\n",n);
else printf("sign(%d) = 0\n",n);
}
else printf("sign(%d) = -1\n",n);
}
22、练习3-4 统计字符
本题要求编写程序,输入10个字符,统计其中英文字母、空格或回车、数字字符和其他字符的个数。
输入格式:
输入为10个字符。最后一个回车表示输入结束,不算在内。
输出格式:
在一行内按照
letter = 英文字母个数, blank = 空格或回车个数, digit = 数字字符个数, other = 其他字符个数
的格式输出。
输入样例:
aZ & 09 Az
输出样例:
letter = 4, blank = 3, digit = 2, other = 1
代码:
#include<stdio.h>
int main()
{
char str[10];
int i;
int letter=0;
int blank=0;
int digit=0;
int other=0;
for(i=0;i<10;i++)
{
scanf("%c",&str[i]);
if(str[i]>='a'&&str[i]<='z'||str[i]>='A'&&str[i]<='Z') letter++;
else if(str[i]==' '||str[i]=='\n') blank++;
else if(str[i]>='0'&&str[i]<='9') digit++;
else other++;
}
printf("letter = %d, blank = %d, digit = %d, other = %d\n",letter,blank,digit,other);
return 0;
}
23、练习3-5 输出闰年
输出21世纪中截止某个年份以来的所有闰年年份。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。
输入格式:
输入在一行中给出21世纪的某个截止年份。
输出格式:
逐行输出满足条件的所有闰年年份,即每个年份占一行。输入若非21世纪的年份则输出"Invalid year!"。若不存在任何闰年,则输出“None”。
输入样例1:
2048
输出样例1:
2004 2008 2012 2016 2020 2024 2028 2032 2036 2040 2044 2048
输入样例2:
2000
输出样例2:
Invalid year!
代码:
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
if(n>=2001&&n<=2100)
{
int temp=0;
int i;
for(i=2001;i<=n;i++)
{
if((i%4==0&&i%100!=0)||i%400==0)
{printf("%d\n",i);temp++;}
}
if(temp==0) printf("None\n");
}
else
printf("Invalid year!\n");
return 0;
}
24、练习3-7 成绩转换
本题要求编写程序将一个百分制成绩转换为五分制成绩。转换规则:
- 大于等于90分为A;
- 小于90且大于等于80为B;
- 小于80且大于等于70为C;
- 小于70且大于等于60为D;
- 小于60为E。
输入格式:
输入在一行中给出一个整数的百分制成绩。
输出格式:
在一行中输出对应的五分制成绩。
输入样例:
90
输出样例:
A
代码:
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
if(n>=90)
printf("A\n");
else
{
if(n>=80)
printf("B\n");
else
{
if(n>=70)
printf("C\n");
else
{
if(n>=60)
printf("D\n");
else
printf("E\n");
}
}
}
}
25、练习3-8 查询水果价格
给定四种水果,分别是苹果(apple)、梨(pear)、桔子(orange)、葡萄(grape),单价分别对应为3.00元/公斤、2.50元/公斤、4.10元/公斤、10.20元/公斤。
首先在屏幕上显示以下菜单:
[1] apple [2] pear [3] orange [4] grape [0] exit
用户可以输入编号1~4查询对应水果的单价。当连续查询次数超过5次时,程序应自动退出查询;不到5次而用户输入0即退出;输入其他编号,显示价格为0。
输入格式:
输入在一行中给出用户连续输入的若干个编号。
输出格式:
首先在屏幕上显示菜单。然后对应用户的每个输入,在一行中按格式“price = 价格”输出查询结果,其中价格保留两位小数。当用户连续查询次数超过5次、或主动输入0时,程序结束。
输入样例1:
3 -1 0 2
输出样例1:
[1] apple [2] pear [3] orange [4] grape [0] exit price = 4.10 price =0.00
输入样例2:
1 2 3 3 4 4 5 6 7 8
输出样例2:
[1] apple [2] pear [3] orange [4] grape [0] exit price = 3.00 price =2.50 price = 4.10 price = 4.10 price = 10.20
代码:
#include<stdio.h>
int main()
{
int n;
int arr[1000];
int i=0;
while(scanf("%d",&arr[i])!=EOF&&arr[i]!=0)
{
i++;
}
int t=i;
printf("[1] apple\n");
printf("[2] pear\n");
printf("[3] orange\n");
printf("[4] grape\n");
printf("[0] exit\n");
int l=1;
for(i=0;i<t;i++)
{
if(arr[i]!=0&&l<=5)
{
if(arr[i]==1) printf("price = 3.00\n");
else if(arr[i]==2) printf("price = 2.50\n");
else if(arr[i]==3) printf("price = 4.10\n");
else if(arr[i]==4) printf("price = 10.20\n");
else printf("price = 0.00\n");
l++;
}
}
return 0;
}
26、习题3-1 比较大小
本题要求将输入的任意3个整数从小到大输出。
输入格式:
输入在一行中给出3个整数,其间以空格分隔。
输出格式:
在一行中将3个整数从小到大输出,其间以“->”相连。
输入样例:
4 2 8
输出样例:
2->4->8
代码:
#include<stdio.h>
int main()
{
int arr[3];
scanf("%d %d %d",&arr[0],&arr[1],&arr[2]);
int i;
int index;
int temp;
int j;
for(i=0;i<2;i++)
{
index=i;
temp=arr[i];
for(j=i+1;j<3;j++)
{
if(arr[j]<=arr[index]) index=j;
}
arr[i]=arr[index];
arr[index]=temp;
}
printf("%d->%d->%d\n",arr[0],arr[1],arr[2]);
return 0;
}
27、习题3-2 高速公路超速处罚
按照规定,在高速公路上行使的机动车,达到或超出本车道限速的10%则处200元罚款;若达到或超出50%,就要吊销驾驶证。请编写程序根据车速和限速自动判别对该机动车的处理。
输入格式:
输入在一行中给出2个正整数,分别对应车速和限速,其间以空格分隔。
输出格式:
在一行中输出处理意见:若属于正常行驶,则输出“OK”;若应处罚款,则输出“Exceed x%. Ticket 200”;若应吊销驾驶证,则输出“Exceed x%. License Revoked”。其中x是超速的百分比,精确到整数。
输入样例1:
65 60
输出样例1:
OK
输入样例2:
110 100
输出样例2:
Exceed 10%. Ticket 200
输入样例3:
200 120
输出样例3:
Exceed 67%. License Revoked
代码:
#include<stdio.h>
int main()
{
int m; //车速
int n; //限速
scanf("%d %d",&m,&n);
int t1=n+n*0.1;
int t2=n+n*0.5;
// printf("%d %d\n",t1,t2);
if(m<t1)
printf("OK\n");
if(m>=t1&&m<t2)
{
double temp1=(m-n)/(double)n*100.0;
double temp2=temp1-(int)temp1;
int temp;
if(temp2>=0.5) temp=(int)temp1+1;
else temp=(int)temp1;
printf("Exceed %d%%. Ticket 200\n",temp);
}
if(m>=t2)
{
double temp1=(m-n)/(double)n*100.0;
double temp2=temp1-(int)temp1;
int temp;
if(temp2>=0.5) temp=(int)temp1+1;
else temp=(int)temp1;
printf("Exceed %d%%. License Revoked\n",temp);
}
}
28、习题3-3 出租车计价
本题要求根据某城市普通出租车收费标准编写程序进行车费计算。具体标准如下:
- 起步里程为3公里,起步费10元;
- 超起步里程后10公里内,每公里2元;
- 超过10公里以上的部分加收50%的回空补贴费,即每公里3元;
- 营运过程中,因路阻及乘客要求临时停车的,按每5分钟2元计收(不足5分钟则不收费)。
输入格式:
输入在一行中给出输入行驶里程(单位为公里,精确到小数点后1位)与等待时间(整数,单位为分钟),其间以空格分隔。
输出格式:
在一行中输出乘客应支付的车费(单位为元),结果四舍五入,保留到元。
输入样例1:
2.6 2
输出样例1:
10
输入样例2:
5.1 4
输出样例2:
14
输入样例3:
12.5 9
输出样例3:
34
代码:
#include<stdio.h>
int main()
{
double k;
int fen;
scanf("%lf %d",&k,&fen);
double money1=fen/5*2.0;
double money2=10.0;
double money;
if(k<3.0) money=money1+money2;
else
{
if(k<10.0) money=money1+money2+(k-3.0)*2.0;
if(k>=10.0) money=money1+money2+(10.0-3.0)*2.0+(k-10.0)*3.0;
}
printf("%.0lf\n",money);
return 0;
}
29、习题3-4 统计学生成绩
本题要求编写程序读入N个学生的百分制成绩,统计五分制成绩的分布。百分制成绩到五分制成绩的转换规则:
- 大于等于90分为A;
- 小于90且大于等于80为B;
- 小于80且大于等于70为C;
- 小于70且大于等于60为D;
- 小于60为E。
输入格式:
输入在第一行中给出一个正整数N(≤1000),即学生人数;第二行中给出N个学生的百分制成绩,其间以空格分隔。
输出格式:
在一行中输出A、B、C、D、E对应的五分制成绩的人数分布,数字间以空格分隔,行末不得有多余空格。
输入样例:
7 77 54 92 73 60 65 69
输出样例:
1 0 2 3 1
代码:
#include<stdio.h>
int main()
{
int N;
scanf("%d",&N);
int i;
int arr[5]={0};
int m;
for(i=0;i<N;i++)
{
scanf("%d",&m);
if(m>=90)arr[0]++;
else if(m<90&&m>=80) arr[1]++;
else if(m<80&&m>=70) arr[2]++;
else if(m<70&&m>=60) arr[3]++;
else arr[4]++;
}
for(i=0;i<5;i++)
{
if(i==5-1) printf("%d\n",arr[i]);
else printf("%d ",arr[i]);
}
return 0;
}
30、习题9-1 时间换算
本题要求编写程序,以hh:mm:ss的格式输出某给定时间再过n秒后的时间值(超过23:59:59就从0点开始计时)。
输入格式:
输入在第一行中以hh:mm:ss的格式给出起始时间,第二行给出整秒数n(<60)。
输出格式:
输出在一行中给出hh:mm:ss格式的结果时间。
输入样例:
11:59:40 30
输出样例:
12:00:10
代码:
#include<stdio.h>
int main()
{
int hh, mm, ss;
scanf("%d:%d:%d",&hh,&mm,&ss);
int n;
scanf("%d",&n);
ss = ss + n;
mm += (ss - ss%60) > 0, ss %= 60;
hh += (mm - mm%60) > 0, mm %= 60;
hh %= 24;
printf("%02d:%02d:%02d",hh,mm,ss);
return 0;
}
31、习题9-3 平面向量加法
本题要求编写程序,计算两个二维平面向量的和向量。
输入格式:
输入在一行中按照“x1 y1 x2 y2 ”的格式给出两个二维平面向量v1=(x1, y1) 和v2=(x2 ,y2) 的分量。
输出格式:
在一行中按照(x, y)的格式输出和向量,坐标输出小数点后一位(注意不能输出−0.0)。
输入样例:
3.5 -2.7 -13.9 8.7
输出样例:
(-10.4, 6.0)
代码:
#include <stdio.h>
#include <math.h>
int main(){
double x1,y1,x2,y2;
double res1,res2;
scanf("%lf %lf %lf %lf",&x1,&y1,&x2,&y2);
res1=x1+x2;
res2=y1+y2;
if(fabs(res1)<0.05){
res1=0.0;//如果满足则置为零
}
if(fabs(res2)<0.05){
res1=0.0;
}
printf("(%.1f, %.1f)",res1,res2);
}
32、习题9-4 查找书籍
给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。
输入格式:
输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。
输出格式:
在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。
输入样例:
3
Programming in C
21.5
Programming in VB
18.5
Programming in Delphi
25.0输出样例:
25.00, Programming in Delphi
8.50, Programming in VB
代码:
#include <stdio.h> // 引入标准输入输出库
#include <string.h> // 引入字符串处理库
struct book{ // 定义一个结构体类型book,包含书名和价格两个成员
char bookname[31]; // 书名,长度为31的字符数组
double price; // 价格,浮点数类型
}ch[10]; // 定义一个结构体数组ch,包含10个book类型的元素
int main(){ // 主函数
int n,i; // 定义整型变量n和i
double max,min; // 定义浮点型变量max和min
int maxi,mini; // 定义整型变量maxi和mini
scanf("%d",&n); // 从标准输入读取一个整数,赋值给n
getchar(); // 读取一个字符,但不使用
for(i=0;i<n;i++){ // 循环n次
gets(ch[i].bookname); // 从标准输入读取一行字符串,存储到ch[i].bookname中
scanf("%lf",&ch[i].price); // 从标准输入读取一个浮点数,赋值给ch[i].price
getchar(); // 读取一个字符,但不使用
}
max=min=ch[0].price; // 将ch[0].price的值赋给max和min
maxi=mini=0; // 将0赋给maxi和mini
for(i=1;i<n;i++){ // 循环n-1次
if(max<ch[i].price){ // 如果ch[i].price大于max
max=ch[i].price; // 将ch[i].price的值赋给max
maxi=i; // 将i赋给maxi
}
if(min>ch[i].price){ // 如果ch[i].price小于min
min=ch[i].price; // 将ch[i].price的值赋给min
mini=i; // 将i赋给mini
}
}
printf("%.2f, %s\n",ch[maxi].price,ch[maxi].bookname); // 打印价格最高的图书的价格和书名
printf("%.2f, %s",ch[mini].price,ch[mini].bookname); // 打印价格最低的图书的价格和书名
}
33、习题9-5 通讯录排序
输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。
输入格式:
输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。
输出格式:
按照年龄从大到小输出朋友的信息,格式同输出。
输入样例:
3
zhang 19850403 13912345678
wang 19821020 +86-0571-88018448
qian 19840619 13609876543
输出样例:
wang 19821020 +86-0571-88018448
qian 19840619 13609876543
zhang 19850403 13912345678
代码:
#include<stdio.h>
struct friends{
char name[20];
int birth;
char number[30];
}num[15],temp;
int main()
{
int n,i,j;
scanf("%d",&n);
for(i=0; i<n; i++)
{
scanf("%s",&num[i].name);
scanf("%d",&num[i].birth);
scanf("%s",&num[i].number ) ;
}
for(i=0;i<n-1;i++)
{
for(j=0;j<n-1-i;j++)
{
if(num[j].birth>num[j+1].birth)
{
temp=num[j+1];
num[j+1]=num[j];
num[j]=temp;
}
}
}
for(i=0;i<n;i++)
{
printf("%s %d ",num[i].name,num[i].birth);
puts(num[i].number);
}
return 0;
}
34、练习4-6 猜数字游戏
猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了(“Too big”),还是小了(“Too small”),相等表示猜到了。如果猜到,则结束程序。程序还要求统计猜的次数,如果1次猜出该数,提示“Bingo!”;如果3次以内猜到该数,则提示“Lucky You!”;如果超过3次但是在N(>3)次以内(包括第N次)猜到该数,则提示“Good Guess!”;如果超过N次都没有猜到,则提示“Game Over”,并结束程序。如果在到达N次之前,用户输入了一个负数,也输出“Game Over”,并结束程序。
输入格式:
输入第一行中给出两个不超过100的正整数,分别是游戏机产生的随机数、以及猜测的最大次数N。最后每行给出一个用户的输入,直到出现负数为止。
输出格式:
在一行中输出每次猜测相应的结果,直到输出猜对的结果或“Game Over”则结束。
输入样例:
58 4
70
50
56
58
60
-2
输出样例:
Too big Too small Too small Good Guess!
代码:
#include <stdio.h>
int main(){
// randNum:随机数 guessNum:用户猜测数 N:次数 flag:标志
int randNum, guessNum, N, flag = 0;
scanf("%d %d", &randNum, &N);
for( int i=1; i<=N; i++ ){ //循环输入N次结束
scanf("%d", &guessNum);
if( guessNum < 0 ) // 输入不合法
break;
if( guessNum > randNum ) // 输入太大
printf("Too big\n");
else if( guessNum < randNum ) // 输入太小
printf("Too small\n");
else if( guessNum == randNum ){ // 相等
if( i == 1 ) // 1次成功
printf("Bingo!\n");
else if( i <= 3 ) // 3次以内成功
printf("Lucky You!\n");
else if( i > 3 ) // 3次以上成功
printf("Good Guess!\n");
flag = 1;
break;
}
}
// 判断是否在N次内猜对
if( flag == 0 )
printf("Game Over\n");
return 0;
}
35、练习4-7 求e的近似值
自然常数e可以用级数1+1/1!+1/2!+⋯+1/n!来近似计算。本题要求对给定的非负整数n,求该级数的前n项和。
输入格式:
输入第一行中给出非负整数n(≤1000)。
输出格式:
在一行中输出部分和的值,保留小数点后八位。
输入样例:
10
输出样例:
2.71828180
代码:
#include<stdio.h>
int main()
{
int n;
double sum=1;
scanf("%d",&n);
if(n<=1000)
{
for(int i=1;i<=n;i++)
{
double fart=1;
for(int j=1;j<=i;j++)
{
fart=fart*j;
}
sum=sum+1.0/fart;
}
printf("%.8f",sum);
}
return 0;
}
36、练习4-10 找出最小值
本题要求编写程序,找出给定一系列整数中的最小值。
输入格式:
输入在一行中首先给出一个正整数n,之后是n个整数,其间以空格分隔。
输出格式:
在一行中按照“min = 最小值”的格式输出n个整数中的最小值。
输入样例:
4 -2 -123 100 0
输出样例:
min = -123
代码:
#include<stdio.h>
int main()
{
int n = 0;
scanf("%d", &n);
int num = 0;
scanf("%d", &num);
int min = num;//最小值初始化
for (int i = 1; i < n; i++)
{
scanf("%d", &num);
if (num < min)//找到更小值
{
min = num;//改变最小值
}
}
printf("min = %d", min);
return 0;
}
37、练习4-11 统计素数并求和
本题要求统计给定整数M和N区间内素数的个数并对它们求和。
输入格式:
输入在一行中给出两个正整数M和N(1≤M≤N≤500)。
输出格式:
在一行中顺序输出M和N区间内素数的个数以及它们的和,数字间以空格分隔。
输入样例:
10 31
输出样例:
7 143
代码:
#include <stdio.h>
#include <math.h>
int prime(int i)
{
int j = 0;
for (j = 2; j <= sqrt(i); j++)
{
if (i % j == 0)
return 0;
}
return 1;
}
int main()
{
int M, N;
int count = 0;
int sum = 0;
int i = 0;
scanf("%d %d", &M, &N);
//判断M的情况
if(M == 1)
{
M++;
//如果M输入的是1,那么此行的作用就是使下面的for循环从2开始
}
//如若输入的数为0,则不符合题意,结束程序
else if(M == 0 || N == 0)
{
printf("0 0");
return 0;
}
for (i = M; i <= N; i++)
{
//利用prime()函数判断是否为素数
if ((prime(i) == 1))
{
count++;
sum = sum + i;
}
}
printf("%d %d\n", count, sum);
//10到31之间素数为:11,13,17,19,23,29,31
return 0;
}
38、习题4-1 求奇数和
本题要求计算给定的一系列正整数中奇数的和。
输入格式:
输入在一行中给出一系列正整数,其间以空格分隔。当读到零或负整数时,表示输入结束,该数字不要处理。
输出格式:
在一行中输出正整数序列中奇数的和。
输入样例:
8 7 4 3 70 5 6 101 -1
输出样例:
116
代码:
#include <stdio.h>
int main(){
int x;
scanf("%d",&x);
int sum = 0;
while(x>0){
if(x%2!=0){
sum += x;
}
scanf("%d",&x);
}
printf("%d\n",sum);
return 0;
}
39、习题4-2 求幂级数展开的部分和
已知函数ex 可以展开为幂级数1+x+x2/2!+x3/3!+⋯+xk/k!+⋯。现给定一个实数x,要求利用此幂级数部分和求ex的近似值,求和一直继续到最后一项的绝对值小于0.00001。
输入格式:
输入在一行中给出一个实数x∈[0,5]。
输出格式:
在一行中输出满足条件的幂级数部分和,保留小数点后四位。
输入样例:
1.2
输出样例:
3.3201
代码:
#include <stdio.h>
#include <math.h>
int main()
{
int k = 1, i;
double x, item = 1, s = 1, sum = 1;
scanf("%lf", &x);
while(fabs(item)>=0.00001)
{
for(i=1; i<=k; i++)
{
sum *= i;
}
item = pow(x, k) / sum;
s += item;
k++;
sum = 1;
}
printf("%.4f", s);
return 0;
}
40、习题4-3 求分数序列前N项和
本题要求编写程序,计算序列 2/1+3/2+5/3+8/5+… 的前N项之和。注意该序列从第2项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中输出部分和的值,精确到小数点后两位。题目保证计算结果不超过双精度范围。
输入样例:
20
输出样例:
32.66
代码:
#include<stdio.h>
int main()
{
double n;
double sum=0;
scanf("%lf",&n);
int i,j,k,temp;
j=2;
k=1;
for(i=1;i<=n;i++)
{
sum=sum+(1.0*j)/(k*1.0);
temp=j;
j=k+j;
k=temp;
}
printf("%.2f",sum);
return 0;
}
41、习题4-4 特殊a串数列求和
给定两个均不超过9的正整数a和n,要求编写程序求a+aa+aaa++⋯+aa⋯a(n个a)之和。
输入格式:
输入在一行中给出不超过9的正整数a和n。
输出格式:
在一行中按照“s = 对应的和”的格式输出。
输入样例:
2 3
输出样例:
s = 246
代码:
#include <math.h>
#include <string.h>
#include <stdio.h>
double p(int a,int n)
{
double s=a;
for(int i=2;i<=n;i++)
{
s=s*10+a;
}
return s;
}
int main()
{
int a,n,i;
double s=0;
scanf("%d %d",&a,&n);
for(i=1;i<=n;i++)
{
s+=p(a,i);
}
printf("s = %.0lf",s);
return 0;
}
42、习题4-6 水仙花数
水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=13+53+33。 本题要求编写程序,计算所有N位水仙花数。
输入格式:
输入在一行中给出一个正整数N(3≤N≤7)。
输出格式:
按递增顺序输出所有N位水仙花数,每个数字占一行。
输入样例:
3
输出样例:
153
370
371
407
代码:
#include<stdio.h>
int main()
{
int i,n,a;
a=1;
scanf("%d",&n);
for(i=1;i<n;i++){ //准备一个最小的n位数在这里就是100;
a=a*10;
}
i=a;
while(i<a*10){ //循环到最大的n位数为止
int t=i;
int sum=0;
do{ //输出该n位数的每位的n次幂
int d=t%10;
t=t/10;
int p=1;
int j=1;
while(j<=n){
p=p*d;
j++;
}
sum=sum+p;
}while(t>0);
if(sum == i){ //如果该n位数每位的n次幂和与该数大小相同,则为水仙花数,输出该数
printf("%d\n",sum);
}
i++;
}
return 0;
}
43、习题4-7 最大公约数和最小公倍数
本题要求两个给定正整数的最大公约数和最小公倍数。
输入格式:
输入在一行中给出两个正整数M和N(≤1000)。
输出格式:
在一行中顺序输出M和N的最大公约数和最小公倍数,两数字间以1空格分隔。
输入样例:
511 292
输出样例:
73 2044
代码:
#include<stdio.h>
int main()
{
int M,N;
scanf("%d %d",&M,&N);
int a,b;
a=M;
b=N;
int temp;
temp=M%N;
while(temp) //辗转相除法求最大公约数
{
M=N;
N=temp;
temp=M%N;
}
printf("%d %d\n",N,a*b/N);
return 0;
}
44、习题7-5 找鞍点
一个矩阵元素的“鞍点”是指该位置上的元素值在该行上最大、在该列上最小。
本题要求编写程序,求一个给定的n阶方阵的鞍点。
输入格式:
输入第一行给出一个正整数n(1≤n≤6)。随后n行,每行给出n个整数,其间以空格分隔。
输出格式:
输出在一行中按照“行下标 列下标”(下标从0开始)的格式输出鞍点的位置。如果鞍点不存在,则输出“NONE”。题目保证给出的矩阵至多存在一个鞍点。
输入样例1:
4
1 7 4 1
4 8 3 6
1 6 1 2
0 7 8 9
输出样例1:
2 1
输入样例2:
2
1 7
4 1
输出样例2:
NONE
代码:
#include<stdio.h>
int fun1(int arr[][7],int i,int n)
{
int j;
int index=0;
for(j=1;j<n;j++)
{
if(arr[i][j]>=arr[i][index]) index=j;
}
return index;
}
int fun2(int arr[][7],int i,int n)
{
int j;
int index=0;
for(j=1;j<n;j++)
{
if(arr[j][i]<=arr[index][i]) index=j;
}
return index;
}
int main()
{
int n;
scanf("%d",&n);
int arr[7][7];
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",&arr[i][j]);
}
}
int l=0;
int temp1,temp2;
for(i=0;i<n;i++)
{
temp1=fun1(arr,i,n);
temp2=fun2(arr,temp1,n);
if(arr[i][temp1]==arr[temp2][temp1])
{
l=1;break;
}
}
if(l==1) printf("%d %d\n",temp2,temp1);
else printf("NONE\n");
return 0;
}
45、练习5-1 求m到n之和
本题要求实现一个计算m~n(m<n)之间所有整数的和的简单函数。
函数接口定义:
int sum( int m, int n );
其中m和n是用户传入的参数,保证有m<n。函数返回的是m~n之间所有整数的和。
裁判测试程序样例:
#include <stdio.h>
int max( int a, int b );//函数声明
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("max = %d\n", max(a, b));//调用函数,返回值给max(a,b)
return 0;
}
int max( int a, int b )
{
int max;
if(a>b)
{
max=a;
}
else
{
max=b;
}
return max;
}
/* 你的代码将被嵌在这里 */
输入样例:
-5 8
输出样例:
sum = 21
代码:
int sum(int m, int n)
{
int i;
int sum=0;
for(i=m;i<=n;i++)
{
sum=sum+i;
}
return sum;
}
46、练习5-2 找两个数中最大者
本题要求对两个整数a和b,输出其中较大的数。
函数接口定义:
int max( int a, int b );
其中a和b是用户传入的参数,函数返回的是两者中较大的数。
裁判测试程序样例:
#include <stdio.h>
int max( int a, int b );
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("max = %d\n", max(a, b));
return 0;
}
/* 你的代码将被嵌在这里 */ 输入样例:
-5 8
输出样例:
max = 8
代码:
int max( int a, int b )
{
if(a>=b)return a;
else return b;
}
47、练习5-3 数字金字塔
本题要求实现函数输出n行数字金字塔。
函数接口定义:
void pyramid( int n );
其中n是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n行数字金字塔。注意每个数字后面跟一个空格。
裁判测试程序样例:
#include <stdio.h>
void pyramid( int n );
int main()
{
int n;
scanf("%d", &n);
pyramid(n);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
5
输出样例:
1
2 2
3 3 3
4 4 4 4
5 5 5 5 5
代码:
void pyramid( int n )
{
int i;
int temp=n;
for(i=1;i<=n;i++)
{
int j=1;
for(;j<temp;j++)
printf(" ");
for(j=1;j<=i;j++)
{
printf("%d ",i);
}
printf("\n");
temp--;
}
}
48、习题5-1 符号函数
本题要求实现符号函数sign(x)。
函数接口定义:
int sign( int x );
其中x是用户传入的整型参数。符号函数的定义为:若x大于0,sign(x) = 1;若x等于0,sign(x) = 0;否则,sign(x) = −1。
裁判测试程序样例:
#include <stdio.h>
int sign( int x );
int main()
{
int x;
scanf("%d", &x);
printf("sign(%d) = %d\n", x, sign(x));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
int sign( int x )
{
if(x>0) return 1;
else if(x==0) return 0;
else return -1;
}
10
输出样例:
sign(10) = 1
代码:
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
较大的数。
函数接口定义:
int max( int a, int b );
其中a和b是用户传入的参数,函数返回的是两者中较大的数。
裁判测试程序样例:
#include <stdio.h>
int max( int a, int b );
int main()
{
int a, b;
scanf("%d %d", &a, &b);
printf("max = %d\n", max(a, b));
return 0;
}
/* 你的代码将被嵌在这里 */ 输入样例:
-5 8
输出样例:
max = 8
代码:
int max( int a, int b )
{
if(a>=b)return a;
else return b;
}
47、练习5-3 数字金字塔
本题要求实现函数输出n行数字金字塔。
函数接口定义:
void pyramid( int n );
其中n是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n行数字金字塔。注意每个数字后面跟一个空格。
裁判测试程序样例:
#include <stdio.h>
void pyramid( int n );
int main()
{
int n;
scanf("%d", &n);
pyramid(n);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
5
输出样例:
1
2 2
3 3 3
4 4 4 4
5 5 5 5 5
代码:
void pyramid( int n )
{
int i;
int temp=n;
for(i=1;i<=n;i++)
{
int j=1;
for(;j<temp;j++)
printf(" ");
for(j=1;j<=i;j++)
{
printf("%d ",i);
}
printf("\n");
temp--;
}
}
48、习题5-1 符号函数
本题要求实现符号函数sign(x)。
函数接口定义:
int sign( int x );
其中x是用户传入的整型参数。符号函数的定义为:若x大于0,sign(x) = 1;若x等于0,sign(x) = 0;否则,sign(x) = −1。
裁判测试程序样例:
#include <stdio.h>
int sign( int x );
int main()
{
int x;
scanf("%d", &x);
printf("sign(%d) = %d\n", x, sign(x));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
int sign( int x )
{
if(x>0) return 1;
else if(x==0) return 0;
else return -1;
}
10
输出样例:
sign(10) = 1
代码:
[外链图片转存中…(img-wdgWABKk-1715700722803)]
[外链图片转存中…(img-komdEIoZ-1715700722803)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新