每天练习3道题,你也可以学会c语言
1.给定一个无序的数组s,找出数组在排序之后,相邻元素之间最大的差值。
如果数组元素个数小于 2,则返回 0。
示例 1:
输入: [3,6,9,1]
输出: 3
解释: 排序后的数组是 [1,3,6,9], 其中相邻元素 (3,6) 和 (6,9) 之间都存在最大差值 3。
#include<stdio.h>
int main()
{
int a[4],i,t,j,max;
for(i=0;i<4;i++){
scanf("%d",&a[i]);
}
for(i=1;i<4;i++){
for(j=0;j<3;j++){
if(a[j]>a[i]){
t=a[j];
a[j]=a[i];
a[i]=t;
}
}
}
max=a[1]-a[0];
for(i=1;i<4;i++){
if(a[i+1]-a[i]>max){
t=max;
max=a[i+1]-a[i];
}
}
printf("%d",max);
return 0;
}
2.给定一个整数 n(n<1000),计算所有小于等于 n 的非负整数中数字 1 出现的个数。
示例 1:
输入:n = 13
输出:6
示例 2:
输入:n = 0
输出:0
#include<stdio.h>
int main()
{
int n,i,y=0,x,z=0;
scanf("n=%d",&n);
if(n==0){
printf("0");
}
if(n<=9){
printf("1");
}
if(n>=10&&n<=99){
for(i=10;i<=n;i++){
int a[2]={i%10,i/10};
for(x=0;x<2;x++){
if(a[x]==1){
y++;
}
}
}
printf("%d",y+1);
}
if(n>=100&&n<=999){
for(i=100;i<=999;i++){
int a[3]={i%10,i/10%10,i/100};
for(x=0;x<3;x++){
if(a[x]==1){
z++;
}
}
}
printf("%d",z+y+1);
}
return 0;
}
3.编写程序,输入10个整数存入一维数组,统计输出其中的正数、负数和零的个数
#include<stdio.h>
int main()
{
int a[10],i,x=0,b=0,c=0;
for(i=0;i<10;i++){
scanf("%d",&a[i]);
}
for(i=0;i<10;i++){
if(a[i]==0){
x++;
}
if(a[i]<0){
b++;
}
if(a[i]>0){
c++;
}
}
printf("%d %d %d",c,b,x);
return 0;
}