基礎c語言例題,c語言簡單例題及解析

本文目錄一覽:

幾道初學者的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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-19 00:39
下一篇 2024-11-19 00:39

相關推薦

  • Python基礎代碼用法介紹

    本文將從多個方面對Python基礎代碼進行解析和詳細闡述,力求讓讀者深刻理解Python基礎代碼。通過本文的學習,相信大家對Python的學習和應用會更加輕鬆和高效。 一、變數和數…

    編程 2025-04-29
  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29
  • AES加密解密演算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密演算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES演算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演著非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • 數據結構與演算法基礎青島大學PPT解析

    本文將從多個方面對數據結構與演算法基礎青島大學PPT進行詳細的闡述,包括數據類型、集合類型、排序演算法、字元串匹配和動態規劃等內容。通過對這些內容的解析,讀者可以更好地了解數據結構與算…

    編程 2025-04-29
  • Python海龜代碼簡單畫圖

    本文將介紹如何使用Python的海龜庫進行簡單畫圖,並提供相關示例代碼。 一、基礎用法 使用Python的海龜庫,我們可以控制一個小海龜在窗口中移動,並利用它的「畫筆」在窗口中繪製…

    編程 2025-04-29
  • Python零基礎PDF下載

    本文將為大家介紹如何使用Python下載PDF文件,適合初學者上手實踐。 一、安裝必要的庫 在Python中,我們需要使用urllib和requests庫來獲取PDF文件的鏈接,並…

    編程 2025-04-29
  • 樹莓派DIY無人機一:製作基礎

    本文將介紹如何使用樹莓派製作一個可飛行的小型無人機。本文將介紹樹莓派的選型、比例積木的使用、無線電通信以及如何控制飛行器的基本運動。 一、樹莓派的選型 在DIY無人機中,樹莓派是必…

    編程 2025-04-29

發表回復

登錄後才能評論