首先聲明,本文
轉帖來自 尼古拉斯的blog(sina)
可是爲何要原創呢,由於我鄙人不喜歡他的排版風格,改了一下,就屬原創
1. 找錯
void test1()
{
char string[10];
char* str1="0123456789";
strcpy(string, str1);
}
答:表面上而且編譯都不會錯誤。但若是string數組原意表示的是字符串的話,那這個賦值就沒有達到意圖。最好定義爲char string[11],這樣最後一個元素能夠存儲字符串結尾符'\0';
void test2()
{
char string[10], str1[10];
for(int I=0; I<10;I++)
{
str1[I] ='a';
}
strcpy(string, str1);
}
答:strcpy使用錯誤,strcpy只有遇到字符串末尾的'\0'纔會結束,而str1並無結尾標誌,致使strcpy函數越界訪問,不妨讓str1[9]='\0',這樣就正常了。
void test3(char* str1)
{
char string[10];
if(strlen(str1)<=10)
{
strcpy(string, str1);
}
}
答:這又會出現第一道改錯題的錯誤了。strlen(str1)算出來的值是不包含結尾符'\0'的,若是str1恰好爲10個字符+1結尾符,string就得不到結尾符了。可將strlen(str1)<=10改成strlen(str1)<10。
2. 寫出程序運行結果
int sum(int a)
{
auto int c=0;
static int b=3;
c+=1;
b+=2;
return(a+b+c);
}
void main()
{
int I;
int a=2;
for(I=0;I<5;I++)
{
printf("%d,", sum(a));
}
}
答:8,10,12,14,16
該題比較簡單。只要注意b聲明爲static靜態全局變量,其值在下次調用時是能夠保持住原來的賦值的就能夠
int func(int a)
{
int b;
switch(a)
{
case 1: b=30;
case 2: b=20;
case 3: b=16;
default: b=0;
}
return b;
}
則func(1)=?
答:func(1)=0,由於沒有break語句,switch中會一直計算到b=0。這是提醒咱們不要忘了break。呵呵。
int a[3];
a[0]=0; a[1]=1; a[2]=2;
int *p, *q;
p=a;
q=&a[2];
則a[q-p]=?
答:a[q-p]=a[2]=2;這題是要告訴咱們指針的運算特色
7.
編寫一個函數,要求輸入年月日時分秒,輸出該年月日時分秒的下一秒。如輸入2004年12月31日23時59分59秒,則輸出2005年1月1日0時0分0秒。
答:
/*輸入年月日時分秒,輸出年月日時分秒的下一秒,輸出仍然在原內存空間*/
void NextMinute(int *nYear,int *nMonth,int *nDate,int *nHour,int *nMinute,int *nSecond)
{
int nDays;
(*nSecond)++; // 秒加1
if(*nSecond>=60) // 秒滿60,作出特殊處理,下面時,日,月等類同
{
*nSecond=0;
(*nMinute)++;
if(*nMinute>=60)
{
*nMinute=0;
(*nHour)++;
if(*nHour>=24)
{
*nHour=0;
(*nDate)++;
switch(*nMonth)
{
case 1:
case 3:
case 5:
case 7:
case 8:
case 10:
case 12: nDays=31;break;
case 2:// 判斷閏年
if(*nYear%400==0||*nYear%100!=0&&*nYear%4==0)
{nDays=29;}
else{nDays=28;}
break;
default:nDays=30;break;
}
if(*nDate>nDays)
{
*nDate=1;
(*nMonth)++;
if(*nMonth>12)
{
*nMonth=1;
(*nYear)++;
}
}
}
}
}
}
/*示例可運行代碼*/
int main()
{
int nYear=2004,nMonth=12,nDate=31,nHour=59,nMinute=59,nSecond=59;
NextMinute(&nYear,&nMonth,&nDate,&nHour,&nMinute,&nSecond);
printf("%d-%d-%d %d:%d:%d\n",nYear,nMonth,nDate,nHour,nMinute,nSecond);
}
2.編程
將整數轉換成字符串:void itoa(int,char);
例如itoa(-123,s[])則s=「-123」;
#include <stdio.h>
#include <stdlib.h>
int myitoa(int value, char*
string)
{
char tmp[33];
char* tp = tmp;
int i;
unsigned v;
// 將值轉爲正值
if (value < 0)
v = -value;
// 將數轉換爲字符放在數組tmp中
while (v)
{
i = v % 10;
v = v / 10;
*(tp++) = i+
'0';
}
// 將tmp裏的字符填入
string指針裏,並加上負號(若是有)
if(
string==
NULL)
{
printf(
"itoa warning:string shoudn't be null\n");
return 0;
}
if (value < 0)
{
*
string =
'-';
string++;
}
while (tp > tmp)
{
*
string = *(--tp);
string++;
}
*
string =
'\0';
return 0;
}
int main()
{
char result[33];
myitoa(-123456,result);
printf(
"main result:%s\n",result);
return 0;
}
主要過程:
好比 -123,先把這個數字變成123,而後獲得3寫入數組,再得2,再得1,再判斷要不要寫個 ‘-’ ,而後在把數組倒過來給 string