本文目錄一覽:
c語言超難題目(對我來說)
同學還是好學的哦
#includestdio.h
viod main()
{
long i; //利潤大於65535了
int bonus1,bonus2,bonus4,bonus6,bonus10,bonus; //獎金就用int了不會超的
scanf(“%ld”,i);
bonus1=100000*0.1; //分別把10-100萬之間的獎金表達式列出
bonus2=bonus1+100000*0.75;
bonus4=bonus2+200000*0.5;
bonus6=bonus4+200000*0.3;
bonus10=bonus6+400000*0.15;
if(i=100000) bonus=i*0.1; //if的嵌套可以做到選擇的目的,每次下面多出的部分都可以用上面的表達式表示出來
else if(i=200000)
bonus=bonus1+(i-100000)*0.075;
else if(i=400000)
bonus=bonus2+(i-200000)*0.05;
else if(i=600000)
bonus=bonus4+(i-400000)*0.03;
else if(i=1000000)
bonus=bonus6+(i-600000)*0.015;
else
bonus=bonus10+(i-1000000)*0.01;
printf(“bonus=%d”,bonus);
}
求問一道超難的C語言題
#includestdio.h
#includestring.h
#includestdlib.h
#define ARR_SIZE 20 //array數組大小
int getkey(int key[]);
int getarray(int array[]);
int insert(int array[],int key,int vol);
int result(int flag);
int main()
{
int M,n,flag,vol;
int array[ARR_SIZE];
int *key;
memset(array,0,sizeof(array));//初始化數組為0
printf(“請輸入M:\n”);
scanf(“%d”,M);
while(M)//循環M次
{
getarray(array);
printf(“請輸入n:\n”);
scanf(“%d”,n);
key=(int *)malloc(n);//根據輸入n申請數組大小
//將數組大小放入數組首位,主要由於你給的 getkey(int key[])只
//有一個參數,無法傳遞數組大小,因此放到手位置傳遞
key[0]=n;
getkey(key);
for(int i=0;i!=n;i++)//key[]中有n個值,因此n次判斷
{
result(insert(array,key[i],ARR_SIZE));
}
memset(array,0,sizeof(array));//清空數組,為下次數據準備
M–;
}
}
int getarray(int array[])
{
printf(“\n請輸入array[](=%d):\n”,ARR_SIZE);
int tmp,i=0;
while(1)
{
scanf(“%d”,tmp);
if(tmp==0)
return 0;
array[i]=tmp;
i++;
}
}
int getkey(int key[])
{
int num=key[0];
for(int i=0;i!=num;i++)
scanf(“%d”,key++);
}
int insert(int array[],int key,int vol)
{
int now_size=0,p=0;
for(int i=0;i!=ARR_SIZE;i++)
{
if(array[i])
now_size++;//統計array[]數組值的個數
if(array[i]==key)
return -2;// The key is already in this array!
if(keyarray[i]array[i])
p++; //該位置就是需要插入的位置
}
if(now_size==ARR_SIZE)
return -1;//The array if full!
for(int i=now_size;i=p;i–)
array[i+1]=array[i];
array[p]=key;
return p; //返回插入位置
}
int result(int flag)
{
if(flag==-1)
printf(“The array if full! “);
else if(flag==-2)
printf(“The key is already in this array! “);
else
printf(“The key is inserted in position %d “,flag);
}
昨天寫好沒測試,今天測了才發給你。這道題目確實不難,只是題目長。另外關於輸出格式有點含糊,如果我理解有偏差,你看了我的代碼改下就好。主要邏輯都已經實現了。
C語言超難的題
對你給的5分我作出以下解答:
第一題:動態規劃求最長非降子序列或最長非升子序列;
第二題:搜索……
10道經典的C語言例題(含參考程序)
1.打印出所有的「水仙花數」,所謂「水仙花數」是指一個三位數,其各位數字立方和等於該數本身。例如,153是一個「水仙花數」,因為153=1^3+5^3+3^3。
#include
#include
int main()
{
int bai_wei,shi_wei,ge_wei,i,sum=0;
for(i=100;i1000;i++)
{
bai_wei=i/100;
shi_wei=(i%100)/10;
ge_wei=i%10;
if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))
{
printf(“%d “,i);
sum++;
if(sum%5==0)
printf(” “);
}
}
printf(” “);
return 0;
}
2.請輸入任意兩個整數x和y,求其最大公約數和最小公倍數。
#include
int main()
{
int x,y,min,max,i;
printf(“請輸入任意兩個整數:”);
scanf(“%d%d”,x,y);
min=xy?y:x;
max=xy?x:y;
for(i=min;i0;i–)
if(x%i==0y%i==0)
{
printf(“這兩個整數的最大公約數為:%d “,i);
break;
}
for(i=max;i=x*y;i++)
if(i%x==0i%y==0)
{
printf(“這兩個整數的最小公倍數為:%d “,i);
break;
}
return 0;
}
3.輸入一行字符,分別統計出其中英文字母、空格、數字和其它字符的個數。
#include
#include
#define N 50
int main()
{
int sum1=0,sum2=0,sum3=0,sum4,i=0;
char str[N];
printf(“請輸入一串字符串:”);
scanf(“%s”,str);
for(i=0;istrlen(str);i++) p=”” /strlen(str);i++)
{
if((str[i]=’a’str[i]=’A’str[i]=’Z’))
sum1++;
if(str[i]==’ ‘)
sum2++;
if(str[i]=’0’str[i]=’9′)
sum3++;
}
sum4=strlen(str)-sum1-sum2-sum3;
printf(“英文字母的個數:%d “,sum1);
printf(“空格的個數:%d “,sum2);
printf(“數字的個數:%d “,sum3);
printf(“其他符號的個數:%d “,sum4);
return 0;
}
4.求s=a+aa+aaa+aaaa+aa…a的值,其中a是一個數字。例如2+22+222+2222+22222(此時共有5個數相加),幾個數相加有鍵盤控制。
#include
#include
int main()
{
int a,n,s=0,i,x=0,y=0;
printf(“請輸入整數a的值:”);
scanf(“%d”,a);
printf(“請輸入相加的個數n:”);
scanf(“%d”,n);
for(i=0;in;i++) p=”” /n;i++)
{
x=y+2*pow(10,i);
y=x;
s=s+x;
}
printf(“s=%d “,s);
return 0;
}
5.一個數如果恰好等於它的因子之和,這個數就稱為「完數」。例如6=1+2+3。編程找出1000以內的所有完數。
#include
int main()
{
int sum=0,i,j;
printf(“在1000以內的完數有:”);
for(i=2;i=1000;i++)
{
for(j=1;ji;j++) p=”” /i;j++)
if(i%j==0)
sum=sum+j;
if(sum==i)
printf(“%d “,i);
sum=0;
}
printf(” “);
return 0;
}
6.輸入一個不多於5位的正整數,要求:1、求它是幾位數;2、逆序打印出個位數字。
#include
int pows(int a,int n)
{
int sum=1,i;
for(i=0;in;i++) p=”” /n;i++)
sum=sum*a;
return sum;
}
int main()
{
int n,i,k,x;
printf(“n=”);
scanf(“%d”,n);
for(i=1;i6;i++)
if(n/pows(10,i)==0)
{
printf(“%d “,i);
k=i;
break;
}
for(i=0;ik;i++) p=”” /k;i++)
{
x=n/pows(10,i)%10;
printf(“%d”,x);
}
printf(” “);
return 0;
}
7.輸入一個5位數,判斷它是不是迴文數。即12321是迴文數,個位與萬位相同,十位與千位相同。
#include
int main()
{
int n,a[5],i=0;
printf(“請輸入一個5位數:”);
scanf(“%d”,n);
while(n!=0)
{
a[i]=n%10;
n=n/10;
i++;
}
if(a[0]==a[4]a[1]==a[3])
printf(“這個數是迴文數 “);
else
printf(“這個數不是迴文數 “);
return 0;
}
8.利用遞歸算法,將所輸入的5個字符,以相反順序打印出來。
#include
void digui(char a[],int n)
{
if(n==1)
printf(“%c”,a[0]);
else
{
printf(“%c”,a[n-1]);
digui(a,n-1);
}
}
int main()
{
char str[5];
printf(“請輸入5個字符:”);
scanf(“%s”,str);
digui(str,5);
printf(” “);
return 0;
}
9.有一分數序列:2/1,3/2,5/3,8/5,13/8,21/13…球出這個序列的前20項之和。
#include
int main()
{
int i,a=1,b=1;
float sum=0.0;
for(i=1;i=20;i++)
{
sum=sum+(float)(a+i)/b;
b=a+i;
a=i;
}
printf(“sum=%f “,sum);
return 0;
}
10.利用遞歸算法求5!。
#include
int digui(int n)
{
if(n==1)
return 1;
else
return n*digui(n-1);
}
int main()
{
int n,sum;
printf(“n:”);
scanf(“%d”,n);
sum=digui(n);
printf(“sum=%d “,sum);
return 0;
}
原創文章,作者:JPUN,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/143404.html