青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我心飛翔

有事不慌,無事不荒,有容乃大,無欲則剛,以德立綱,外圓內(nèi)方。

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  1 隨筆 :: 9 文章 :: 13 評論 :: 0 Trackbacks
這篇文章是九九年寫的,這篇文章適合中級程序員。有不明白之處不要緊,多看幾遍,然后花些時間上機操作及認真思考每個問題。遇到難題要研究、解決,難題出現(xiàn)于哪里?該用什么方式來解決?為什么要選擇這個方式解決?有其它的解決方法嗎?這樣的解決方案完美嗎?其實做個程序員這些基本的思考心得是要掌握的。記住;遇問題不要逃避,要面對現(xiàn)實、勇于挑戰(zhàn),仔細研究難題的所在,這樣相信你會成功的!

  指針結(jié)構(gòu)與指針的關系亦有兩重:其一是在定義結(jié)構(gòu)時,將指針作為結(jié)構(gòu)中的一個成員;其二是指向結(jié)構(gòu)的指針(稱為結(jié)構(gòu)指針)。前者同一般的結(jié)構(gòu)成員一樣可直接進行訪問,后者是本節(jié)討論的重點。
結(jié)構(gòu)指針說明的一般形式是:
struct 結(jié)構(gòu)類型名稱 * 結(jié)構(gòu)指針變量名;
例如:struct date * pdate, today;
說明了兩個變量,一個是指向結(jié)構(gòu)date的結(jié)構(gòu)指針pdate,today是一個date結(jié)構(gòu)變量。語句:
pdate = &today;

pdate today (struct date)

  year
  month
  day
  

  通過結(jié)構(gòu)變量today訪問其成員的操作,也可以用等價的指針形式表示:
today.year = 2001;  等價于  (*pdate).year = 2001;
由于運算符"*"的優(yōu)先級比運算符"."的優(yōu)先級低,所以必須有"( )"將*pdate括起來。若省去括號,則含義就變成了"*(pdate.year)"。
在C語言中,通過結(jié)構(gòu)指針訪問成員可以采用運算符"->"進行操作,對于指向結(jié)構(gòu)的指針,為了訪問其成員可以采用下列語句形式:
結(jié)構(gòu)指針->成員名;
這樣,上面通過結(jié)構(gòu)指針pdate訪問成員year的操作就可以寫成:
pdate->year = 2001;
如果結(jié)構(gòu)指針p指向一個結(jié)構(gòu)數(shù)組,那么對指針p的操作就等價于對數(shù)組下標的操作。
  結(jié)構(gòu)指針是指向一種結(jié)構(gòu)類型的指針變量,它是結(jié)構(gòu)在內(nèi)存中的首地址,結(jié)構(gòu)指針具有一般指針的特性,如在一定條件下兩個指針可以進行比較,也可以與整數(shù)進行加減。但在指針操作時應注意:進行地址運算時的放大因子由所指向的結(jié)構(gòu)的實際大小決定。
例11-7:用結(jié)構(gòu)指針改寫加密程序。
#include "stdio.h"
struct table
{ char input, output;
} ;
struct table translate[ ]=
{ 'a', 'd', 'b', 'w', 'c', 'k', 'd', ';' , 'e', 'i',
'i', 'a', 'k', 'b', ';', 'c', 'w', 'e'
};       /* 建立加密對照表 */
main( )
{ char ch;
struct table *p, *pend; /* p和pend為指向結(jié)構(gòu)table的指針 */
pend = & translate[ sizeof(translate)/sizeof(struct table)-1 ];
/* pend指向結(jié)構(gòu)數(shù)組translate的最后一個元素 */
while ( (ch=getchar( )) != '\n')
{ for ( p=translate ; p->input!=ch && p!=pend; p++ ) ;
if ( p->input==ch )
putchar( p->output);
else
putchar (ch);
}
}


讀者可以將兩個程序?qū)φ臻喿x,體會結(jié)構(gòu)指針特點。程序中用pend指向數(shù)組的最后一個元素。
由于結(jié)構(gòu)指針和在結(jié)構(gòu)中將指針作為成員,使得對于結(jié)構(gòu)變量的運算和對成員的操作變得較為復雜。由于取內(nèi)容的"*"與"."和"->"運算符的優(yōu)先級與結(jié)合性不同,使得對成員的訪問和操作又增加了一層難度,再因為"++"和"--"運算所具有的"先操作"與"后操作"的特性,以及"++"和"--"運算的結(jié)合性,使得"++"和--"運算與結(jié)構(gòu)操作混合在一起時,實際操作會更為復雜。


例11-8:請分析程序的運算結(jié)果。
#include "stdio.h"
struct s
{ int x, *y; /* y: 結(jié)構(gòu)中的成員是指向整型的指針 */
} *p; /* p: 指向結(jié)構(gòu)的指針 */
int data[5]={10, 20, 30, 40, 50,}; /* data: 整型數(shù)組 */
struct s array[5]=
{ 100, &data[0], 200, &data[1], 300, &data[2],
400, &data[3], 500, &data[4]
}; /* array: 結(jié)構(gòu)數(shù)組 */
main ( )
{ p=array; /* 指針p指向結(jié)構(gòu)數(shù)組的首地址 */
printf ("For printer:\n");
printf ("%d\n", p->x);
printf ("%d\n", (*p).x);
printf ("%d\n", *p->y);
printf ("%d\n", *(*p).y);
printf ("%d\n", ++p->x);
printf ("%d\n", (++p)->x);
printf ("%d\n", p->x++);
printf ("%d\n", p->x);
printf ("%d\n", ++ (*p->y));
printf ("%d\n", ++ * p->y);
printf ("%d\n", * ++ p->y);
printf ("%d\n", p->x);
printf ("%d\n", * (++p)->y);
printf ("%d\n", p->x);
printf ("%d\n", * p->y ++);
printf ("%d\n", p->x);
printf ("%d\n", * (p->y) ++);
printf ("%d\n", p->x);
printf ("%d\n", * p ++ ->y);
printf ("%d\n", p->x);
}


結(jié)構(gòu)數(shù)組array的初始化后的狀態(tài)如圖11.4所示。程序中指針操作的含義如下:
p->x /* 取結(jié)構(gòu)指針p指向的結(jié)構(gòu)的成員x的值,輸出 100 */
(*p).x /* 取結(jié)構(gòu)指針p的內(nèi)容的成員x的值,功能同上,輸出 100 */
*p->y /* 取結(jié)構(gòu)指針p的指針成員y的內(nèi)容,輸出 10 */
*(*p).y /* 取結(jié)構(gòu)指針p的內(nèi)容的指針成員y的內(nèi)容,功能同上,輸出10 */
++p->x /* p所指的x加1,x先加1后再輸出 101 ,p不加1 */
(++p)->x /* p先加1后再取x的值,x不加1,輸出 200 */
p->x++ /* 先取x的值后x再加1,輸出 200 */
p->x /* 輸出 201 */
++(*p->y) /* p所指的y的內(nèi)容先加1,輸出 21 ,p不加1,y也不加1 */
++ *p->y /* 同上,由運算的結(jié)合性隱含了括號,輸出 22 */
* ++p->y /* y先加1后再取y的內(nèi)容,輸出30,p不加1,y的內(nèi)容不加1 */
p->x /* 輸出 201 */
*(++p)->y /* p先加1后取所指y的內(nèi)容,輸出 30 */
p->x /* 輸出 300 */
*p->y ++ /* 取p所指的y的內(nèi)容,輸出 30,然后p所指的y加1 */
p->x /* 輸出 300 */
*(p->y)++ /* 取p所指的y的內(nèi)容,輸出 40,然后p所指的y加1 */
p->x /* 輸出 300 */
*p++->y /* 取p所指的y的內(nèi)容,輸出 50,然后p加1 */
p->x /* 輸出 400 */

程序運行結(jié)束時,指針與結(jié)構(gòu)數(shù)組array的狀態(tài)如圖11-7所示。

例11-9:可用一個結(jié)構(gòu)表示學生的學號和成績,編寫程序,對班中30名學生按成績進行排序,并輸出排序后的學號、成績和全班平均分。
#include <stdio.h>
#define STNUM 30 /* 全班同學人數(shù) */
struct stuinf
{ int stid; /* 學生學號 */
int score; /* 學生成績 */
} stu[STNUM]; /* stu: 結(jié)構(gòu)數(shù)組 */
main ( )
{ struct stuinf *ptemp, /* ptemp:指向結(jié)構(gòu)的指針, 臨時變量 */
*p[STNUM]; /* p:指向結(jié)構(gòu)的指針構(gòu)成的指針數(shù)組 */
int i, j, k, sum=0; /* i,j,k:臨時變量;sum:分數(shù)累計 */
for (i=0; i<=STNUM-1; i++) /* 輸入學生的學號和成績 */
{ scanf ("%d%d", &stu[i].stid, &stu[i].score); /* 輸入學生的學號和成績 */
p[i] = &stu[i];
/* 指針數(shù)組p[i]的第i個指針(元素)指向結(jié)構(gòu)數(shù)組的第i個元素 */
sum += stu[i].score;      /* 累計學生的分數(shù) */
}
for ( i=0; i<=STNUM-2; i++ ) /* 排序操作 */
{ k = i; /* k:在第i次循環(huán)中,指向當前最高分的指針在指針數(shù)組p中的下標 */
for (j=i; j<=STNUM-1; j++)
if (p[k]->score < p[j]->score) k=j;
/* 查找當前最大值, k中存放最大值對應的指針在指針數(shù)組p中的下標 */
if ( k!=i ) /* 當k不等于i時,交換兩個指向結(jié)構(gòu)的指針 */
{ ptemp = p[i];
p[i] = p[k];
p[k] = ptemp;
}
}
for (i=0; i<=STNUM-1; i++) /* 按排序順序輸出學號和成績 */
printf("%d,%d\n", (*p[i]).stid, p[i]->score);
printf ("average score = %d\n", sum/STNUM); /* 輸出平均分 */
}


  程序中使用了較為復雜的數(shù)據(jù)結(jié)構(gòu),包括:結(jié)構(gòu)數(shù)組stu,指向結(jié)構(gòu)的指針ptemp,由指向結(jié)構(gòu)的指針構(gòu)成的指針數(shù)組p。
程序在結(jié)構(gòu)數(shù)組stu和指針數(shù)組p之間建立了對應的指針關系,從而為簡化后續(xù)處理打下了良好的基礎。在排序過程中,程序使用選擇排序的思想,先查找確定當前的最大值,再進行一次有實效的數(shù)據(jù)交換。進行數(shù)據(jù)交換時,也沒有交換結(jié)構(gòu)數(shù)據(jù)本身,而是交換了指向結(jié)構(gòu)數(shù)據(jù)的指針。在輸出時,按照排序后指針的順序,輸出排序后的數(shù)據(jù)。

posted on 2005-10-19 00:49 無情雨 閱讀(535) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区在线视频| 亚洲欧美日韩区| 欧美日韩综合在线| 欧美精品在线免费播放| 欧美成人69av| 欧美噜噜久久久xxx| 欧美视频免费在线| 国产亚洲福利| 亚洲国内精品| 中文国产一区| 久久av资源网站| 亚洲第一区在线观看| 欧美激情视频在线免费观看 欧美视频免费一 | 久久久五月婷婷| 欧美大胆a视频| 国产精品日韩精品欧美在线| 国产亚洲一区二区在线观看| 亚洲激情在线| 久久精品视频99| 亚洲精品资源| 久久九九99视频| 欧美三区美女| 一区二区三区在线观看欧美| 亚洲图片自拍偷拍| 免播放器亚洲| 亚洲欧美精品suv| 欧美刺激午夜性久久久久久久| 欧美日韩精品是欧美日韩精品| 国产欧美三级| 亚洲视频在线播放| 亚洲第一免费播放区| 欧美亚洲综合网| 国产精品v欧美精品v日韩精品| 尤物yw午夜国产精品视频| 亚洲网址在线| 亚洲激情网址| 久久精品久久综合| 这里只有精品电影| 欧美日韩国产欧| 亚洲国产日韩在线一区模特| 羞羞色国产精品| 亚洲美女91| 欧美激情综合五月色丁香小说| 狠狠色狠狠色综合| 欧美一级在线播放| 亚洲视频在线看| 欧美四级在线| 亚洲已满18点击进入久久| 欧美激情精品久久久久久大尺度| 亚洲欧美亚洲| 国产精品一区在线播放| 另类春色校园亚洲| 欧美一区二区三区四区视频| 亚洲欧洲日韩女同| 欧美 日韩 国产 一区| 激情自拍一区| 久久蜜臀精品av| 欧美怡红院视频| 欧美一区二区视频观看视频| 欧美午夜一区二区| 亚洲一区区二区| 亚洲深夜影院| 国产精品日本一区二区| 欧美一区二区日韩| 午夜精品久久久久久久久久久久久| 国产精品porn| 久久国产99| 美女诱惑一区| 亚洲视频在线观看一区| 亚洲欧美春色| 在线观看一区二区视频| 亚洲国产精品一区二区三区| 欧美日韩国产a| 小嫩嫩精品导航| 麻豆视频一区二区| 欧美大片专区| 亚洲综合首页| 欧美一区二区免费视频| 亚洲级视频在线观看免费1级| 亚洲激情在线视频| 国产免费成人在线视频| 美日韩免费视频| 欧美日韩网址| 久热精品视频在线| 欧美三级乱人伦电影| 久久久噜噜噜久久狠狠50岁| 欧美国产激情| 久久大香伊蕉在人线观看热2| 久久一二三区| 亚洲欧美亚洲| 麻豆成人在线| 亚洲欧美精品伊人久久| 久久午夜影视| 亚洲欧美国产制服动漫| 久久久久久穴| 亚洲欧美综合另类中字| 久久久午夜电影| 一区二区三区鲁丝不卡| 西瓜成人精品人成网站| 日韩午夜免费视频| 欧美在线视频二区| 亚洲深夜激情| 另类尿喷潮videofree| 香蕉久久久久久久av网站| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲欧美中文日韩在线| 免费日韩av| 欧美在线视频在线播放完整版免费观看| 老司机午夜精品视频在线观看| 欧美亚洲综合网| 欧美精品 国产精品| 久久久精品国产免大香伊| 欧美激情亚洲一区| 鲁大师影院一区二区三区| 国产精品女同互慰在线看| 一区二区成人精品| 亚洲国产精品久久久久婷婷老年| 亚洲午夜国产成人av电影男同| 亚洲国产小视频| 久久精品国产96久久久香蕉| 亚洲欧美中日韩| 国产精品乱码一区二区三区| 亚洲精品欧洲| 一区二区三区**美女毛片| 噜噜噜躁狠狠躁狠狠精品视频 | 亚洲一区亚洲二区| 欧美黄色日本| 亚洲国产精品va在线看黑人| 伊人久久噜噜噜躁狠狠躁| 久久黄色影院| 免费亚洲电影在线观看| 亚洲国产成人久久| 欧美成人精品在线| 亚洲日本中文字幕区| 一二三区精品福利视频| 欧美视频免费看| 亚洲免费在线电影| 久久久久久久久久久久久久一区| 国产午夜精品久久| 久久婷婷久久| 亚洲精品日韩在线| 亚洲欧美欧美一区二区三区| 国产农村妇女精品一二区| 羞羞色国产精品| 久久在线播放| 亚洲精品系列| 欧美午夜在线一二页| 亚洲欧美激情一区| 久久综合久久综合这里只有精品 | 欧美视频精品在线| 一区二区高清视频在线观看| 亚洲欧美在线播放| 国产日韩精品视频一区二区三区| 亚洲在线黄色| 久久综合久久综合九色| 亚洲日韩欧美一区二区在线| 欧美日韩精品不卡| 亚洲一品av免费观看| 久久久久国产成人精品亚洲午夜| 激情成人综合| 欧美麻豆久久久久久中文| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲在线1234| 亚洲高清资源| 国产精品福利在线观看网址| 先锋影音网一区二区| 欧美成人日韩| 亚洲一区在线免费观看| 好看的日韩视频| 欧美人与禽猛交乱配视频| 亚洲欧美日韩国产中文| 亚洲国产精品99久久久久久久久| 亚洲视频 欧洲视频| 国产一区二区三区精品久久久| 欧美国产高潮xxxx1819| 欧美在线免费视屏| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久精品国产一区二区电影| 欧美大片在线看免费观看| 久久国产精品久久久久久| 亚洲一区二区在线看| 韩国v欧美v日本v亚洲v| 欧美日韩一区二区三区高清| 欧美在线免费一级片| 9色porny自拍视频一区二区| 久久色在线播放| 亚洲欧美一区二区三区极速播放| 亚洲精品字幕| 亚洲电影欧美电影有声小说| 国产精品免费aⅴ片在线观看| 老司机成人网| 性欧美18~19sex高清播放| 日韩视频在线观看| 欧美激情一区二区三区在线视频观看 | 亚洲国产欧美一区二区三区同亚洲| 欧美一区二区三区精品电影| 亚洲美女av黄| 亚洲国产va精品久久久不卡综合| 国产一区二区0| 国产精品日韩精品|