O‘zbekiston respublikasi axborot texnologiyalari va kommunikatsiyalarini rivojlantirish vazirligi muhammad al-xorazmiy nomidagi toshkent axborot texnologiyalari universiteti axborot xavfsizligi


Chiziqli bir tomonlama yo‘nalgan ro‘yhatlar


Download 135.7 Kb.
bet2/2
Sana24.07.2023
Hajmi135.7 Kb.
#1662026
1   2
Bog'liq
Ma’lumotlar tuzilmasi va algoritmlar fanidan Labaratoriya ishi-fayllar.org

3.2. Chiziqli bir tomonlama yo‘nalgan ro‘yhatlar




Chiziqli bir bog‘lamli ro‘yhatlar
Bir bog‘lamli ro‘yhat deb elementlarning shunday tartiblangan ketma-ketligiga aytiladiki, har bir element 2 ta maydonga: informatsion maydon info va ko‘rsatkich maydoni ptr ga ega bo‘ladi (3.2-rasm).
Mazkur ko‘rinishdagi ro‘yhat elementi ko‘rsatkichining o‘ziga xosligi shundan iboratki, u faqatgina ro‘yhatning navbatdagi (o‘zidan keyin keluvchi) elementi adresini ko‘rsatadi. Bir tomonlama yo‘naltirilgan ro‘yhatda eng so‘ngi element ko‘rsatkichi bo‘sh, ya’ni NULL bo‘ladi.


Lst – ro‘yhat boshi ko‘rsatkichi. U ro‘yhatni yagona bir butun sifatida ifodalaydi. Ba’zan ro‘yhat bo‘sh bo‘lishi ham mumkin, ya’ni ro‘yhatda bitta ham element bo‘lmasligi mumkin. Bu holda lst = NULL bo‘ladi. Hozir chiziqli bir bog‘lamli ro‘yhat hosil qilish dasturini ko‘rib chiqsak. Buning uchun biz foydalanuvchi tomonidan yaratiladigan nostandart toifa yaratib olishimiz kerak. Buning bir qancha usullari mavjud, ya’ni klasslar yoki strukturalar bilan amalga oshirish mumkin.
24-variant
Bo’sh bo’lmagan binar daraxtning eng katta va eng kichik kalitli tugunlarini o’rta arifmetigiga teng kalitli tugunni berilgan daraxtga qo’yish algoritmi va dasturini keltiring
Dastur kodi :
#include
using namespace std;
int main()
{
string it1, it2;

list myList;


list::iterator it;
int n;
cout << "Ro'yxatdagi elementlar sonini kiriting: ";

cin >> n;


cout << "\nRo'yxat elementlarini kiriting:\n";
for(int i = 1; i <= n; i ++)
{
string elm;

cin >> elm;


myList.push_back(elm);
} cout<<"\n_____________________________________________________________________________\n\n";
it1=*myList.begin();
for (it=myList.begin(); it!=myList.end(); ++it){
it2 = *it;
if(it1.size() < it2.size()){
it1 = it2;
}
}

myList.remove(it1);


myList.push_front (it1);


cout << "Saralangan ro`yhat: \n";
for (it=myList.begin(); it!=myList.end(); ++it){
cout << *it << "\n";

}
cout << "\n\n";


system("pause"); return 0;



}


http://fayllar.org
Download 135.7 Kb.

Do'stlaringiz bilan baham:
1   2




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©fayllar.org 2024
ma'muriyatiga murojaat qiling