本文目錄一覽:
幾道初學者的c語言題目
(1)
#include “stdio.h”
void change(int numsSource[][20], int numsDest[][20]){
char i,j,k;
for(i=0;i20;i++)
for(j=0;j20;j++)
numsDest[j][i]=numsSource[i][j];
}
int main(int argv,char *argc[]){
int a[20][20],b[20][20],n,i,j;
printf(“Input n(int 0n21)…\n”);
if(scanf(“%d”,n)!=1 || n1 || n20){
printf(“Input error, exit…\n”);
return 0;
}
for(i=0;in;i++){
for(j=0;jn;j++){
scanf(“%d”,a[i]+j);
printf(“%6d”,a[i][j]);
}
printf(“\n”);
}
change(a,b);
printf(“\nAfter the transpose:\n”);
for(i=0;in;i++){
for(j=0;jn;printf(“%6d”,b[i][j++]));
printf(“\n”);
}
return 0;
}
運行樣例:
(2)題意與輸入、輸出要求不符,就不做了吧?
(3)
#include “stdio.h”
#include stdlib.h
int main(int argv,char *argc[]){
int N,k,m,n,q,*p,t;
printf(“Input N(int 0N100001,0 end)…\nN=”);
while(1){
if(scanf(“%d”,N)!=1 || N1 || N100000){
if(N==0)
printf(“You have chosen to quit…\n”);
else
printf(“Input error, exit…\n”);
return 0;
}
if((p=(int *)malloc(sizeof(int)*N))==NULL){
printf(“Application memory failure,exit…\n”);
exit(0);
}
printf(“Input %d integer(s)…\n”,N);
for(m=0;mN;scanf(“%d”,p+m++));
printf(“Input k(int N=k0)…\nk=”);
scanf(“%d”,k);
for(t=m=0;mN;m++){
for(q=m,n=q+1;nN;n++)
if(p[q]p[n])
q=n;
if(m!=q)
n=p[m],p[m]=p[q],p[q]=n;
printf(“%6d”,p[m]);
if(!t k==p[m])
t=m+1;
}
printf(“\n”);
printf(t ? “It is at %d\n\n” : “No find…\n\n”,t);
free(p);
}
return 0;
}
運行樣例:
(4)
#include “stdio.h”
int main(int argv,char *argc[]){
int a[50],i,j,k,n;
printf(“Input n(int 0n50,0 end)…\n”);
while(1){
printf(“n=”);
if(scanf(“%d”,n)!=1 || n1 || n49){
if(n==0)
printf(“You have chosen to quit…\n”);
else
printf(“Input error, exit…\n”);
return 0;
}
printf(“Input %d integer(s)…\n”,n);
for(i=0;in;scanf(“%d”,a+i++));
printf(“a[0] = %d\n”,a[0]);
for(i=0;in;i++){
for(k=i,j=k+1;jn;j++)
if(a[k]a[j])
k=j;
if(k-i)
j=a[k],a[k]=a[i],a[i]=j;
printf(“%6d”,a[i]);
}
printf(“\n\n”);
}
return 0;
}
運行樣例:
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;
}
5道c語言 基礎題目 求解
16.計算存放在數組score中12位學生成績的平均分,並輸出高於平均分的人數。
#include stdio.h
void main()
{
int score[N]={67,78,66,79,73,82,69,85,77,80,93,72};
int i;
float s = 0;
for(i = 0; i N; i++)
{
s += score[i];
}
s = s/N;
int n = 0;
for(i = 0; i N; i++)
{
if(score[i] s)
n++;
}
printf(“%d\n”, n);
getch();
}
21. 編寫一main函數,實現以下功能:定義一個4*4的整型二維數組,
將自然數1至16按行順序存入該數組中,然後輸出該數組左上半三角。即在屏幕上輸出:
1 2 3 4
5 6 7
9 10
13
#include stdio.h
#define N 4
void main()
{
int array[N][N];
int i,j;
int n = 1;
for (i = 0; i N; ++i)
{
for (j = 0; j N; ++j)
{
array[i][j] = n;
n++;
}
}
for (i = 0; i N; ++i)
{
for (j = 0; j N – i; ++j)
{
printf(“%d\t”, array[i][j]);
}
printf(“\n”);
}
getch();
}
22. 輸入一個用24小時製表示的時間(h:m),把它轉換為用12小時製表示的時間並輸出。
例如: 輸入 9:05
輸出 9:05AM
輸入 12:10
輸出 12:10PM
輸入 14:30
輸出 2:30PM
#include stdio.h
void main()
{
int h,m;
scanf(“%d:%d”,h,m); //”:” 是英文的
char str[10];
if (h = 12) //中午12:00算下午
{
str = “PM”;
if(h 12)
h = h – 12;
}
else
str = “AM”;
printf(“%d:%d%s\n”,h,m,str);
}
23. .輸入一個百分製成績,輸出相應的五級製成績。百分製成績與五級製成績之間的轉換標準為:
90分以上為A,80-89分為B,70-79分為C,60-69分為D,60以下為E。
例1:輸入 :95
輸出:A
例2:輸入:63
輸出:D
#include stdio.h
void main()
{
int n;
scanf(“%d”,n);
switch(n/10)
{
case 9:
printf(“A\n”);
break;
case 8:
printf(“B\n”);
break;
case 7:
printf(“C\n”);
break;
case 6:
printf(“D\n”);
break;
default:
printf(“E\n”);
break;
}
}
24. 輸入一個年份和一個月份,輸出該年的這個月有多少天。(應考慮是否閏年:閏年條件為:該年份能被4整除,但不能被100整除,或是能被400整除。)
例1: 輸入1965-2
輸出 d=28
例2: 輸入1984-2
輸出d=29
#include stdio.h
void main()
{
int year;
int month;
scanf(“%d%d”,year,month);
int num = 0;
switch(month)
{
case 1:
num = 31;
break;
case 2:
{
if(year%400 == 0 || (year%4 == 0 year%100 != 0))
num = 29;
else
num = 28;
}
break;
case 3:
num = 31;
break;
case 4:
num = 30;
break;
case 5:
num = 31;
break;
case 6:
num = 30;
break;
case 7:
num = 31;
break;
case 8:
num = 31;
break;
case 9:
num = 30;
break;
case 10:
num = 31;
break;
case 11:
num = 30;
break;
case 12:
num = 31;
break;
}
printf(“%d\n”, num);
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/158205.html