c語言入門題
『壹』 c語言題目基礎題
22題:m*n=3+1*2+3=8 選B
18題:x--(第一次x值是x-1後的值即為0)x=0[假],++y(第一次y的值為y初始值為-1,第二次才是y=y+1)y=-1[假], 結果:假&&假=真 選A
5題 A應為 int a,b=0(是逗號,不是等號),d double為雙精度浮點型,保留兩位小數點,改為float才正確,故 a,d為錯誤選項
『貳』 c語言入門基礎題!
答:(1) 因為42、43對應的ASCII碼為*、+,所以用%c輸出是:*、+;因為42、43二進制數8位表示為:0010 1010、0010 1011,沒有超過8位可表示的最大正數127,所以用%d輸出是42、43。
(2) 因為242、243對應的擴展ASCII碼為≥、≤,所以用%c輸出是:≥、≤;因為242、243二進制數8位表示為:1111 0010、1111 0011,超過8位可表示的最大正數127,所以用%d輸出時將其視為負數,1111 0010、1111 0011分別為-14、-13,故輸出為:-14、-13。
(3) 當程序中c1,c2的定義改為int c1,c2;時。(1)的情況與原來相同;
(2)輸出對應的擴展ASCII碼仍然為≥、≤;因為242、243都在int類型數據的正數范圍內,所以用%d輸出時就是:242、243。
『叄』 C語言入門題目,求詳細易懂的解答過程。
答案為第一行:Tony。
解答:for循環共循環2次,然後strcpy(a,b)比較兩串字元大小,如果strcpy值大於0,則a大於b。具體的比較是看字元串的字母的ASCII碼的大小,如果相同,再繼續比較第二個,這個不贅述。
主要看一下name[],對於一維數組來講,它是元素,對於二維數組來講,它不是具體的元素,而是代表的一維數組。比如name[3][20],為3行20列,那麼name[0],它代表的是組成二維數組的第一維數組。又知道puts()括弧里可以放一維數組名,可以輸出它裡面的字元串,對放name[0]的話,那就是輸出3行20列中的第一行字元串。
通過for比較我們已經得出結果,即兩次for循環都不符合條件,因此,m沒有變化,=0。所以puts(nam[0])的話,就是輸出Tony。
望樓主採納。
『肆』 c語言入門題
照字面上的意思,nextchar就是「下一個字元」。
for(;nextchar!=' ';)
就是當 nextchar 不是回車符時就一直循環,結合循環體中的
scanf("%c",&nextchar);
用來讀取一整行字元,直到讀到回車符時結束循環。
#include<stdio.h>
intmain()
{intletter=0,space=0,number=0,others=0;
charnextchar;
printf("Inputyourstring "); //提示輸入字元串
for(;nextchar!=' ';) //nextchar不是回車符就循環
{scanf("%c",&nextchar); //讀入一個新的字元
if(('a'<=nextchar&&nextchar<='z')||('A'<=nextchar&&nextchar<='Z'))//如nextchar是字母
letter++;
elseif(nextchar=='') //如nextchar是空格
space++;
elseif('0'<=nextchar&&nextchar<='9') //如nextchar是數字
number++;
else //以上都不是
others++;
}
printf("letter=%d,space=%d,number=%d,others=%d ",letter,space,number,--others);
}
『伍』 求解C語言基礎題。
一、平台:數組中連續相等的元素就是一個平台。
二、最長平台:就是在所有平台中找出最長的那個。
三、方法不止一種,從完整程序思路,至少包含一個實現功能的函數及列印輸出的函數。
下面是我寫的演示代碼:
遍歷數組,找出最長平台,返回其在數組中起點和終點位置(返回值是指針數組)。異常直接拋出自行處理。
#include<stdio.h>
#define ML 20
int **findMaxG(int nums[],int len);//找出最長平台,並返回平台起始和結束的位置(指針數組)。異常返回NULL
int showMaxG(int *pMax[2]);//列印輸出最長的平台。異常返回0
int main()
{
int **pMax=NULL;
int nums[ML]={1,1,2,3,3,3,4,5,6,6,7,7,7,7,8,8,8,9,10,10};
pMax=findMaxG(nums,ML);
return !showMaxG(pMax);
}
int showMaxG(int *pMax[2])
{
int *p0=pMax[0];
if(pMax[0]==NULL || pMax[1]==NULL || pMax[1]<pMax[0]) return 0;
printf("最長平台為:");
while(p0<=pMax[1])
printf("%d ",*p0++);
printf(" ");
return 1;
}
int **findMaxG(int nums[],int len)
{
static int *pMax[2];
int n=1,maxn=1,*p0=nums,*p1=nums;
if(len<=0) return NULL;
pMax[0]=pMax[1]=nums;
while(p0<&nums[len-1])
{
p1=p0+1;
while(p1<&nums[len-1])//統計當前平台長度
{
if(*p1!=*p0)//開始統計新的平台,之前平台在p1-1處結束
break;
else
n++,p1++;
}
if(n>maxn)
maxn=n,pMax[0]=p0,pMax[1]=p1-1;//記錄最大的平台
p0=p1,n=1;//復位,准備統計下一個平台
}
return pMax;
}
『陸』 C語言入門題
首先說明一下,這道題目的答案卻是是 3。
我在編譯器運行了一下你的代碼:
接下來分析一下這個題目的流程:
1、在if(x < y)這個判斷條件中,x==1, y==-1,條件是不成立的,所以走else分支。
2、在else分支中,z==2,現在 z+=1之後, z==3。
3、在最後一步printf中列印最終結果z == 3。
如果以上回答對你有幫助,請採納下,謝謝。
『柒』 C語言結構體章節入門題目如下
void
input(char
a[]){
char
*s;int
k=0;
scanf("%s",s);
while(s){a[k++]=*s;s++;}
}
//input
void
sort(int
a[],int
n){
//n為數組元素個數
int
i,j=n-1;
int
flag=1,tp;
while(flag){
flag=0;i=0;
while(i<j){
if(a[i]>a[i+1]){tp=a[i];
a[i]=a[i+1];a[i+1]=tp;
flag=1;}
}
--j;
}
}//Bubble_Sort
int
search(int
a[],int
n,int
key){//n是實際元素個數,應小於數組大小
int
low=0,high=n-1;
int
mid;
while(low<=high){
mid=(low+high)/2;
if(a[mid]==key)
return
mid;
else
if(a[mid]>key)
high=mid-1;
else
low=mid+1;
}
for(int
i=n-1;i>=low;--i)
a[i+1]=a[i];
a[low]=key;
return
-1;
//所查關鍵字不在數組中
}
『捌』 c語言經典100題,要過程
您好,c語言經典100題:
【程序1】
題目:有1,2,3,4個數字,能組成多少個互不相同且無重復數字的三位數
都是多少
1.程序分析:可填在百位,十位,個位的數字都是1,2,3,4.組成所有的排列後再去
掉不滿足條件的排列.
2.程序源代碼:
main()
{
int
i,j,k;
printf("\n");
for(i1;i<5;i++)
/*以下為三重循環*/
for(j1;j<5;j++)
for
(k1;k<5;k++)
{
if
(i!k&&i!j&&j!k)
/*確保i,j,k三位互不相同*/
printf("%d,%d,%d\n",i,j,k);
}
}
【程序2】
題目:企業發放的獎金根據利潤提成.利潤(i)低於或等於10萬元時,獎金可提10%;利潤高
於10萬元,低於20萬元時,低於10萬元的部分按10%提成,高於10萬元的部分,可可提
成7.5%;20萬到40萬之間時,高於20萬元的部分,可提成5%;40萬到60萬之間時高於
40萬元的部分,可提成3%;60萬到100萬之間時,高於60萬元的部分,可提成1.5%,高於
100萬元時,超過100萬元的部分按1%提成,從鍵盤輸入當月利潤i,求應發放獎金總數
1.程序分析:請利用數軸來分界,定位.注意定義時需把獎金定義成長整型.
2.程序源代碼:
main()
{
long
int
i;
int
bonus1,bonus2,bonus4,bonus6,bonus10,bonus;
scanf("%ld",&i);
bonus1100000*0.1;bonus2bonus1+100000*0.75;
bonus4bonus2+200000*0.5;
bonus6bonus4+200000*0.3;
bonus10bonus6+400000*0.15;
if(i<100000)
bonusi*0.1;
else
if(i<200000)
bonusbonus1+(i-100000)*0.075;
else
if(i<400000)
bonusbonus2+(i-200000)*0.05;
else
if(i<600000)
bonusbonus4+(i-400000)*0.03;
else
if(i<1000000)
bonusbonus6+(i-600000)*0.015;
else
bonusbonus10+(i-1000000)*0.01;
printf("bonus%d",bonus);
}
【程序3】
題目:一個整數,它加上100後是一個完全平方數,再加上168又是一個完全平方數,請問該數是多少
1.程序分析:在10萬以內判斷,先將該數加上100後再開方,再將該數加上268後再開方,如果開方後
的結果滿足如下條件,即是結果.請看具體分析:
2.程序源代碼:
#include
"math.h"
main()
{
long
int
i,x,y,z;
for
(i1;i2)/*如果是閏年且月份大於2,總天數應該加一天*/
sum++;
printf("it
is
the
%dth
day.",sum);}
【程序4】
題目:輸入某年某月某日,判斷這一天是這一年的第幾天?
1.程序分析:以3月5日為例,應該先把前兩個月的加起來,然後再加上5天即本年的第幾天,特殊
情況,閏年且輸入月份大於3時需考慮多加一天。
2.程序源代碼:
main()
{
int
day,month,year,sum,leap;
printf("\nplease
input
year,month,day\n");
scanf("%d,%d,%d",&year,&month,&day);
switch(month)/*先計算某月以前月份的總天數*/
{
case
1:sum0;break;
case
2:sum31;break;
case
3:sum59;break;
case
4:sum90;break;
case
5:sum120;break;
case
6:sum151;break;
case
7:sum181;break;
case
8:sum212;break;
case
9:sum243;break;
case
10:sum273;break;
case
11:sum304;break;
case
12:sum334;break;
default:printf("data
error");break;
}
sumsum+day;
/*再加上某天的天數*/
if(year%4000||(year%40&&year%100!0))/*判斷是不是閏年*/
leap1;
else
leap0;
if(leap1&&month>2)/*如果是閏年且月份大於2,總天數應該加一天*/
sum++;
printf("It
is
the
%dth
day.",sum);}
【程序5】
題目:輸入三個整數x,y,z,請把這三個數由小到大輸出.
1.程序分析:我們想辦法把最小的數放到x上,先將x與y進行比較,如果x>y則將x與y的值進行交換,
然後再用x與z進行比較,如果x>z則將x與z的值進行交換,這樣能使x最小.
2.程序源代碼:
main()
{
int
x,y,z,t;
scanf("%d%d%d",&x,&y,&z);
if
(x>y)
{tx;xy;yt;}
/*交換x,y的值*/
if(x>z)
{tz;zx;xt;}/*交換x,z的值*/
if(y>z)
{ty;yz;zt;}/*交換z,y的值*/
printf("small
to
big:
%d
%d
%d\n",x,y,z);
}
【程序6】
題目:用*號輸出字母c的圖案.
1.程序分析:可先用'*'號在紙上寫出字母c,再分行輸出.
2.程序源代碼:
#include
"stdio.h"
main()
{
printf("hello
c-world!\n");
printf("
****\n");
printf("
*\n");
printf("
*
\n");
printf("
****\n");
}
【程序7】
題目:輸出特殊圖案,請在c環境中運行,看一看,very
beautiful!
1.程序分析:字元共有256個.不同字元,圖形不一樣.
2.程序源代碼:
#include
"stdio.h"
main()
{
char
a176,b219;
printf("%c%c%c%c%c\n",b,a,a,a,b);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",a,a,b,a,a);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",b,a,a,a,b);}
【程序8】
題目:輸出9*9口訣.
1.程序分析:分行與列考慮,共9行9列,i控制行,j控制列.
2.程序源代碼:
#include
"stdio.h"
main()
{
int
i,j,result;
printf("\n");
for
(i1;i<10;i++)
{
for(j1;j<10;j++)
{
resulti*j;
printf("%d*%d%-3d",i,j,result);/*-3d表示左對齊,佔3位*/
}
printf("\n");/*每一行後換行*/
}
}
【程序9】
題目:要求輸出國際象棋棋盤.
1.程序分析:用i控制行,j來控制列,根據i+j的和的變化來控制輸出黑方格,還是白方格.
2.程序源代碼:
#include
"stdio.h"
main()
{
int
i,j;
for(i0;i<8;i++)
{
for(j0;j<8;j++)
if((i+j)%20)
printf("%c%c",219,219);
else
printf("
");
printf("\n");
}
}
【程序10】
題目:列印樓梯,同時在樓梯上方列印兩個笑臉.
1.程序分析:用i控制行,j來控制列,j根據i的變化來控制輸出黑方格的個數.
2.程序源代碼:
#include
"stdio.h"
main()
{
int
i,j;
printf("\1\1\n");/*輸出兩個笑臉*/
for(i1;i<11;i++)
{
for(j1;j<i;j++)
printf("%c%c",219,219);
printf("\n");
}
}
【程序11】
題目:古典問題:有一對兔子,從出生後第3個月起每個月都生一對兔子,小兔子長到第三個月
後每個月又生一對兔子,假如兔子都不死,問每個月的兔子總數為多少
1.程序分析:
兔子的規律為數列1,1,2,3,5,8,13,21....
2.程序源代碼:
main()
{
long
f1,f2;
int
i;
f1f21;
for(i1;i<20;i++)
{
printf("%12ld
%12ld",f1,f2);
if(i%20)
printf("\n");/*控制輸出,每行四個*/
f1f1+f2;
/*前兩個月加起來賦值給第三個月*/
f2f1+f2;
/*前兩個月加起來賦值給第三個月*/
}
}
【程序12】
題目:判斷101-200之間有多少個素數,並輸出所有素數.
1.程序分析:判斷素數的方法:用一個數分別去除2到sqrt(這個數),如果能被整除,
則表明此數不是素數,反之是素數.
2.程序源代碼:
#include
"math.h"
main()
{
int
m,i,k,h0,leap1;
printf("\n");
for(m101;m<200;m++)
{
ksqrt(m+1);
for(i2;i<k;i++)
if(m%i0)
{leap0;break;}
if(leap)
{printf("%-4d",m);h++;
if(h%100)
printf("\n");
}
leap1;
}
printf("\nthe
total
is
%d",h);
}
『玖』 大學c語言入門題
題意是要你將英文前兩個字母和中文做成數據列表。然後通過遍歷匹配查詢。
對於保存該數據列表,可以用2維數組,可以用結構,也可以用資料庫或文件。
我這里用數組的方法寫了一個,你參考。 原理:利用數組在內存中地址是連續的。
#include<stdio.h>
#definerow7//列錶行數
#defineclo9//列表列數
char*findc(charc[3],intn);
//參數c:查找的字元;n:正常調用傳值0。
//功能:通過字元,匹配數組列表每行首字母。無匹配返回NULL;有唯一匹配,返回中文對應首地址;如有多個匹配對比每行第二個字母
intmain()
{
charc[3],*str;
while(1)
{
printf("輸入首字母:");
scanf("%c",&c[0]);
c[1]=c[2]=0;
getchar();
str=findc(c,0);
printf("代表%s
",str);
}
return0;
}
char*findc(charc[3],intn)
{
charweek[row][clo]={"Mo星期一","Tu星期二","We星期三","Th星期四","Fr星期五","Sa星期六","Su星期天"},*p=&week[0][0],*pSave;
intcount=0;//記錄匹配成功次數
while(p<=&week[row-1][clo-1])
{
if(c[0]==*p&&c[0+n]==*(p+n))
{
pSave=p+2;
count++;
}
p+=clo;
}
if(count==1)
returnpSave;
if(count>1)
{
printf("請輸入一個字元:");
scanf("%c",&c[1]);
getchar();
returnfindc(c,1);
}
else
returnNULL;
}
『拾』 幾道初學者的c語言題目
(1)
#include"stdio.h"
voidchange(intnumsSource[][20],intnumsDest[][20]){
chari,j,k;
for(i=0;i<20;i++)
for(j=0;j<20;j++)
numsDest[j][i]=numsSource[i][j];
}
intmain(intargv,char*argc[]){
inta[20][20],b[20][20],n,i,j;
printf("Inputn(int0<n<21)... ");
if(scanf("%d",&n)!=1||n<1||n>20){
printf("Inputerror,exit... ");
return0;
}
for(i=0;i<n;i++){
for(j=0;j<n;j++){
scanf("%d",a[i]+j);
printf("%6d",a[i][j]);
}
printf(" ");
}
change(a,b);
printf(" Afterthetranspose: ");
for(i=0;i<n;i++){
for(j=0;j<n;printf("%6d",b[i][j++]));
printf(" ");
}
return0;
}
運行樣例: