第一篇:西北農(nóng)林科技大學(xué) c語(yǔ)言上機(jī) 實(shí)習(xí)5答案
實(shí)習(xí)五答案
1、用指針實(shí)現(xiàn)排序
/* exer 5-1 由鍵盤(pán)輸入 10個(gè)整數(shù),將它們按由小到大順序排列 */ #include
int a[10],*p = NULL;
/* 說(shuō)明數(shù)組和指針 */
int i, j, temp;
for(p = a;p < a + 10;p++)
/* 指針從數(shù)組首到尾 */
{
scanf(“%d”, p);
/* 利用指針依次輸入 */
}
p = a;
for(i = 0;i < 9;i++)
/* 利用指針依次比較 */
{
for(j = i + 1;j < 10;j++)
if(*(p + i)> *(p + j))
{
temp = *(p + i);
*(p + i)= *(p + j);
*(p + j)= temp;
}
}
for(p=a;p < a + 9;p++)
printf(“%d ”, *p);
printf(“%dn”, *p);}
2、用指針實(shí)現(xiàn)字符串排序
/*exer 5-2 將 10個(gè)長(zhǎng)度小于20的字符串排序*/ #include
char szStr[10][20],*psz[10],szTemp[20];
int i,j;
for(i = 0;i < 10;i++)
{
psz[i] = szStr[i];
/*指針數(shù)組的每個(gè)元素指向各行串*/
}
for(i = 0;i < 10;i++)
{
gets(psz[i]);
/*輸入10個(gè)字符串*/
}
for(i = 0;i < 9;i++)
/*字符串排序*/
{
for(j = i + 1;j < 10;j++)
{
if(strcmp(psz[i], psz[j])> 0)
{
strcpy(szTemp, psz[i]);
strcpy(psz[i], psz[j]);
strcpy(psz[j], szTemp);
}
}
}
for(i = 0;i < 10;i++)
{
puts(psz[i]);
/*輸出字符串*/
} }
3、數(shù)據(jù)倒置
/*exer 5-3 將具有10個(gè)元素的一維數(shù)組中的數(shù)據(jù)倒置 */ #include
int a[10], iTemp, *p, *q;
int i;
for(i = 0;i < 10;i++)
{
scanf(“%d”, a + i);
/*輸入數(shù)組*/
}
p = a;
q = a + 9;
for(p = a, q = a + 9;p < q;p++, q--)
/*首尾交換*/
{
iTemp = *p;
*p = *q;
*q = iTemp;
}
for(i = 0;i < 10;i++)
{
printf(“%d ”, *(a + i));
/*輸出*/
} }
4、用指針實(shí)現(xiàn)數(shù)據(jù)位置調(diào)整 /*exer 5-4 輸入 10個(gè)整數(shù),將最大的調(diào)到最后,最小的調(diào)到最前*/ #include
void swap(int *px, int *py);
int main(void){
int a[10], iTemp, *pMax, *pMin;
int i;
for(i = 0;i < 10;i++)
{
scanf(“%d”, a + i);/*輸入數(shù)組*/
}
pMax = a;
/*最大值指針指向數(shù)組首地址*/
pMin = a;
/*最小值指針指向數(shù)組首地址*/
for(i = 1;i < 10;i++)
{
if(*(a+i)> *pMax)
pMax = a + i;
if(*(a+i)< *pMin)
pMin = a + i;
}
/*最大值是第1個(gè)元素,最小值是最后一個(gè)元素*/
if(pMax == a && pMin == a + 9)
{
swap(pMax, pMin);
}
else
{
/*最小值與第一個(gè)元素交換*/
swap(a, pMin);
/*最大值與最后一個(gè)元素交換*/
swap(a + 9, pMax);
}
for(i = 0;i < 10;i++)
{
printf(“%d ”, *(a + i));
/*輸出*/
}
return 0;}
void swap(int *px, int *py){
int temp;
temp = *px;
*px = *py;
*py = temp;}
5、用指針實(shí)現(xiàn)查找二維數(shù)組中最大數(shù)及其位置
/*exer 5-5 找出二維數(shù)組(設(shè)3行4列)中的最大數(shù)及其位置 */ #include
int a[3][4],(*p)[4], iCol, iRow;
int i, j;
p = a;
for(i = 0;i < 3;i++)
{
for(j = 0;j < 4;j++)
scanf(“%d”, *(p + i)+ j);
/*輸入數(shù)組*/
}
iCol = 0;
/*設(shè)最大數(shù)及其位置 */
iRow = 0;
for(i = 0;i < 3;i++)
{
for(j = 0;j < 4;j++)
{
if(*(*(p + i)+ j)> *(*(p + iRow)+ iCol))
{
iRow = i;
iCol = j;
/*修改位置*/
}
}
}
printf(“%d %d %dn”, iRow, iCol, a[iRow][iCol]);}
6、用指針實(shí)現(xiàn)子字符串提取
/*exer 5-6 由鍵盤(pán)輸入一串字符,從字符串下標(biāo)為m開(kāi)始
取出n個(gè)字符(m和n由鍵盤(pán)輸入),形成一個(gè)新的字符串
*/ #include
char szStrSour[80], szStrDest[80], *pszSour, *pszDest;
int i, m, n;
gets(szStrSour);
/* 輸入字符串 */
scanf(“%d%d”, &m, &n);
/* 輸入位置和長(zhǎng)度 */
pszSour = szStrSour + m;
/* 確定起始位置 */
pszDest = szStrDest;
for(i = 0;i < n;i++)
/* 依次取n個(gè)字符 */
{
*pszDest = *pszSour;
pszDest++;
pszSour++;
}
*pszDest = '