2016 7 25 鏈表

  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 /* 
  4 usingnamespacestd;
  5  
  6 structNode
  7 {
  8   int  data;//數據域
  9   struct Node*next;//指針域
 10 };
 11  
 12 /*
 13 Create
 14 *函數功能:創建鏈表.
 15 *輸入:各節點的data
 16 *返回值:指針head
 17 *//* 
 18 Node*Create()
 19 {
 20   int  n=0;
 21   Node*head,*p1,*p2;
 22   p1=p2=new Node;
 23   cin>>p1->data;
 24   head=NULL;
 25 while(p1->data!=0)
 26 {
 27     if(n==0)
 28    {
 29      head=p1;
 30    }
 31    else
 32     p2->next=p1;
 33     p2=p1;
 34     p1=new Node;
 35     cin>>p1->data;
 36     n++;
 37 }
 38     p2->next=NULL;
 39     return head;
 40 }
 41  
 42 /*
 43 insert
 44 *函數功能:在鏈表中插入元素.
 45 *輸入:head鏈表頭指針,p新元素插入位置,x新元素中的數據域內容
 46 *返回值:無
 47 void insert(Node*head,int p,int x)
 48 {
 49    Node*tmp=head;//for循環是為了防止插入位置超出了鏈表長度
 50    for(inti=0;i<p;i++)
 51    {
 52      if(tmp==NULL)
 53      return -1;
 54      if(i<p-1) 
 55      tmp=tmp->next;
 56     }
 57     Node*tmp2=new Node;
 58       tmp2->data=x;
 59       tmp2->next=tmp->next;
 60       tmp->next=tmp2;
 61 }
 62  */
 63 /*
 64 del
 65 *函數功能:刪除鏈表中的元素
 66 *輸入:head鏈表頭指針,p被刪除元素位置
 67 *返回值:被刪除元素中的數據域.如果刪除失敗返回-1
 68 intdel(Node*head,int p)
 69 {
 70    Node*tmp=head;
 71    for(inti=0;i<p;i++)
 72    {
 73       if(tmp==NULL)
 74       return -1;
 75       if(i<p-1)
 76         tmp=tmp->next;
 77 }
 78    int ret=tmp->next->data;
 79    tmp->next=tmp->next->next;
 80    return ret;
 81 }
 82  
 83 void print(Node*head)
 84 {
 85     for(Node*tmp=head;tmp!=NULL;tmp=tmp->next)
 86       printf("%d",tmp->data);
 87       printf("\n");
 88 }
 89  
 90 int main()
 91 {
 92   Node*head;
 93   head=newNode;
 94   head->data=-1;
 95   head->next=NULL;
 96   return 0;
 97 }
 98 */ 
 99 //例子
100 #include<iostream>
101 //#define NULL 0
102 struct student
103 {
104    long num;
105    struct student*next;
106 };
107 int main()
108 {
109    int i,n;
110    student*p=(struct student*)malloc(sizeof(struct  student));
111    student*q=p;
112    printf("輸入幾個值");
113    scanf("%d",&n);  
114    for(i=1;i<=n;i++)
115    {
116      scanf("%d",&(q->num));
117      q->next=(struct student*)malloc(sizeof(struct student));
118      q=q->next;
119     }
120      printf("值第幾個");
121      int rank;
122      scanf("%d%d",&(q->num),&rank);
123      student*w=p;
124      for(i=1;i<rank-1;i++)
125      {
126         w=w->next;
127     }
128     q->next=w->next;
129     w->next=q;
130     for(i=1;i<=n+1;i++)
131     {
132       printf("%d",p->num);
133       p=p->next;
134     }
135     return 0;
136 }//指針后移麻煩鏈表形式循環鏈表  */ 

?

轉載于:https://www.cnblogs.com/sysu-eeman-yang/p/5987505.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/457112.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/457112.shtml
英文地址,請注明出處:http://en.pswp.cn/news/457112.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

php數值操作,php數值計算num類簡單操作示例

php數值計算num類簡單操作示例,在線,計算器,小數,整數,程序設計php數值計算num類簡單操作示例易采站長站&#xff0c;站長之家為您整理了php數值計算num類簡單操作示例的相關內容。本文實例講述了php數值計算num類簡單操作。分享給大家供大家參考&#xff0c;具體如下&#xff…

YAML-學習筆記!

YAML學習筆記 一、YAML簡介 YAML&#xff0c;即YAML Ain’t Markup Language的縮寫&#xff0c;YAML 是一種簡潔的非標記語言。YAML以數據為中心&#xff0c;使用空白&#xff0c;縮進&#xff0c;分行組織數據&#xff0c;從而使得表示更加簡潔易讀。 二、YAML語法 1、基本規…

CentOS遠程監控

近日&#xff0c;因工作需要&#xff0c;學習了CentOS遠程監控的水平有限&#xff0c;多指教。 遠程訪問CentOS&#xff0c;包括三種方式ssh&#xff0c;telnet&#xff0c;vnc。 本例涉及的是以vnc遠程訪問CentOS。指令在root下操作。注意&#xff1a;vnc的端口為5900&#xf…

aix oracle 10.2.0.1 升級 10.2.0.4,AIX Oracle RAC 升級到10.2.0.4.0要特別注意的問題 - 愛肯的專欄 ......

AIX Oracle RAC 升級到10.2.0.4.0過程有如下報錯(直接升級到10.2.0.4不需要應用Patch:6160398)&#xff1a;rootbwgl_db2:/u01/app/oracle/crs_1/bin# /u01/app/oracle/crs_1/install/root102.shError : Please change the CRS_ORACLE_USER id to have the following OS capabi…

將文件提交到github的兩種方法

方法一 簡要步驟如下&#xff1a; 登陸github&#xff0c;創建git倉庫。記此git倉庫的地址為[github_repository_url]&#xff0c;例如git倉庫的地址&#xff1a;https://github.com/galian123/nodejs_http_server 在本地的工程目錄執行git init&#xff0c;此工程目錄是要提…

Visual Studio 2017新版發布,極大提高開發效率丨附下載

最新的Visual Studio 2017免費下載&#xff1a;https://www.evget.com/product...【包含Professional、Enterprise、Community版本】 為任何開發、應用和平臺提供無與倫比的效率&#xff0c;Visual Studio 2017 候選發布。 提高了效率 代碼導航、IntelliSense、重構、代碼修復和…

BGP路由協議詳解(完整篇)

原文鏈接&#xff1a;http://xuanbo.blog.51cto.com/499334/465596/ 2010-12-27 12:02:45 上個月我寫一篇關于BGP協議的博文&#xff0c;曾許諾過要完善這個文檔&#xff0c;但因最近的工作和授課很忙&#xff0c;所以沒有時間進行完善。為了實現這個承諾&#xff0c;我在去外…

oracle 備份導出,oracle 怎么備份或導入導出表

exp/imp下面介紹的是導入導出的實例&#xff0c;向導入導出看實例基本上就可以完成&#xff0c;因為導入導出很簡單。數據導出&#xff1a;1 將數據庫TEST完全導出,用戶名system 密碼manager 導出到D:\daochu.dmp中exp system/managerTEST filed:\daochu.dmp fully2 將數據庫中…

GitHub+Hexo搭建自己的Blog之-本地環境部署01

前言 之前我的博客沒有綁自己的域名&#xff0c;一直在github上放著&#xff0c;訪問起來比較麻煩&#xff0c;前陣子在阿里云買了這個域名&#xff0c;配置上之后&#xff0c;就可以通過自己的域名訪問了&#xff0c;有些朋友問我這個博客怎么搭的&#xff0c;用的什么主題&am…

appsettings 連接oracle數據庫,ABP .net core集成訪問Oracle數據庫

1.添加包引用&#xff1a;Microsoft.EntityFrameworkCore.RelationalOracle.EntityFrameworkCore2.重寫DbContext OnModelCreating/// /// 判斷如果是Oracle&#xff0c;需要執行Schema/// /// protected override void OnModelCreating(ModelBuilder modelBuilder){//判斷當前…

Day08-函數(3)

import functools #偏函數 def demo(a,b,c,d):print(a,b,c,d)# def partital_demo(a,b): # demo(a,b,3,4) # partital_demo(1,2)#實現偏函數 # #固定前兩個 # demo functools.partial(demo,5,6) # demo(10,50)# #固定后兩個 # demofunctools.partial(demo,c3,d5) # demo(1…

使用VS2010編譯Qt 5.6.1過程記錄

由于Qt官方發布的Qt 5.6.1二進制安裝包沒有對應VS2010版本的&#xff0c;而我的電腦上只安裝了VS2010&#xff0c;因此只能自己編譯。 本文記錄本人的編譯安裝過程&#xff0c;以及其中遇到的一些問題。 本文使用VS2010 32位編譯Qt 5.6.1。 1. 下載Qt源代碼 Qt源代碼下載地址&…

golang 指針

指針1、簡單的定義一個指針package mainimport "fmt"func main(){var p *inti :2p &ifmt.Println("memory address i:",p) } //執行結果&#xff1a; memory address i: 0xc42000a2e02、打印指針的值package mainimport "fmt"func main(){v…

php防錯處理,更好的PHP錯誤處理

錯誤類型PHP 主要有兩種錯誤&#xff1a;觸發錯誤和異常。其中觸發錯誤大概可以分為&#xff1a;編譯錯誤、引擎錯誤和運行時錯誤&#xff0c;其中前兩個是無法捕獲的&#xff1b;異常都是可以捕獲的&#xff0c;當沒有嘗試捕獲時則會中斷代碼。觸發錯誤可以通過 error_get_las…

Windows安裝Apache注冊服務出現(OS 5)拒絕訪問。 : AH00369: Failed to open the Windows service manager,

windows安裝Apache&#xff0c;注冊服務出現“(OS 5)拒絕訪問。 : AH00369: Failed to open the WinNT service manager..."錯誤 在安裝Apache的時候&#xff0c;我下載的是zip格式&#xff0c;不是msi安裝版&#xff0c;需要自己注冊服務&#xff0c;才能在桌面任務欄里有…

算法與數據結構(三) 二叉樹的遍歷及其線索化(Swift版)

前面兩篇博客介紹了線性表的順序存儲與鏈式存儲以及對應的操作&#xff0c;并且還聊了棧與隊列的相關內容。本篇博客我們就繼續聊數據結構的相關東西&#xff0c;并且所涉及的相關Demo依然使用面向對象語言Swift來表示。本篇博客我們就來介紹樹結構的一種&#xff1a;二叉樹。在…

關于android開發時,發生Error infalting classa com.baidu.mapapi.map.MapView的解決辦法

1.問題描述&#xff1a;百度地圖SDK中 Error&#xff1a; infalting classa com.baidu.mapapi.map.MapView 。 2.解決辦法&#xff1a;通過1個多小時的上網搜索&#xff0c;最終發現很多網友之所以出現這方面的問題有以下幾種原因&#xff1a; &#xff08;1&#xff09;.忘…

c++動態綁定的技術實現

1 什么是動態綁定 有一個基類&#xff0c;兩個派生類&#xff0c;基類有一個virtual函數&#xff0c;兩個派生類都覆蓋了這個虛函數。現在有一個基類的指針或者引用&#xff0c;當該基類指針或者引用指向不同的派生類對象時&#xff0c;調用該虛函數&#xff0c;那么最終調用的…

linux替換某個文件夾下所有文件,Linux 批量查找并替換文件夾下所有文件的內容...

1.批量查找某個目下文件的包含的內容cd etcgrep -rn "查找的內容" ./2.批量替換某個目下所有包含的文件的內容cd etcsed -i "s/查找的內容/替換后的內容/g" grep -rl "查找的內容" ./3.批量查找并替換任意文件夾下的文件內容。sed -i "s/要…

Day09-遞歸

#模擬棧結構 stack [] #壓棧&#xff08;想棧里存數據&#xff09; stack.append("A") print(stack) stack.append("B") print(stack) stack.append("C") print(stack)#出棧&#xff08;在棧里取數據&#xff09; res stack.pop() print("…