這樣:
創新互聯公司是一家專業提供桑植企業網站建設,專注與成都網站建設、網站制作、H5技術、小程序制作等業務。10年已為桑植眾多企業、政府機構等服務。創新互聯專業網絡公司優惠進行中。
#includestdio.h
// 計算字符串長度
int len(char a[])
{
int temp=0,i;
for(i=0;a[i]!='\0';i++)
temp++;
return temp;
}
// 獲取子串在源串中首次出現的位置索引
int index(char a[], char b[])
{
int i,j,temp;
for(i=0;ilen(a)-len(b);i++)
{
temp=i;
j=0;
while(j=len(b) a[temp]==b[j])
{
temp++;
j++;
}
if(j==len(b))
return i;
}
return -1;//返回-1則沒找到指定的子串,否則找到
}
void main()
{
char a[]="hello";
a[len(a)]=' ';//算法改進,在數組a的末尾新增一個空的元素,這樣才能hello中找到hello
printf("%d\n",index(a,"llo"));
}
擴展資料:
注意事項
頭文件:#include string.h
strchr() 用來查找某字符在字符串中首次出現的位置,其原型為:
char * strchr (const char *str, int c);
參數:str 為要查找的字符串,c 為要查找的字符。
strchr() 將會找出 str 字符串中第一次出現的字符 c 的地址,然后將該地址返回。
注意:字符串 str 的結束標志 NUL 也會被納入檢索范圍,所以 str 的組后一個字符也可以被定位。
返回值:如果找到指定的字符則返回該字符所在地址,否則返回 NULL。
返回的地址是字符串在內存中隨機分配的地址再加上你所搜索的字符在字符串位置。設字符在字符串中首次出現的位置為 i,那么返回的地址可以理解為 str + i。
提示:如果希望查找某字符在字符串中最后一次出現的位置,可以使用?strrchr()?函數。
實例:查找字符5首次出現的位置。
#include?stdio.h
#include?stdlib.h
#include?string.h
int?main(){
char?*s?=?"0123456789012345678901234567890";
char?*p;
p?=?strchr(s,?'5');
printf("%ld\n",?s);
printf("%ld\n",?p);
system("pause");
return?0;
}
輸出結果:
12016464
12016469
1.索引表的類型可定義如下:
struct IndexItem
{
IndexKeyType index;
//IndexKeyType為事先定義的索引值類型
int start;
//子表中第一個元素所在的下標位置
int length;
//子表的長度域
};
2.首先根據給定的索引值K1,在索引表上查找出索引值等于K1的索引項,以確定對應子表在主表中的開始位置和長度,然后再根據給定的關鍵字K2,在對應的子表中查找出
3。關鍵字等于K2的元素。
設數組A是具有mainlist類型的一個主表,數組B是具有indexlist類型的在主表A上建立的一個索引表,m為索引表B的實際長度,即所含的索引項的個數,K1和K2分別為給定
帶查找的索引值和關鍵字,并假定每個子表采用順序存儲,則索引查找算法為:
int Indsch(mainlist A, indexlist B, int m, IndexKeyType K1, KeyType K2)
{//利用主表A和大小為 m 的索引表B索引查找索引值為K1,關鍵字為K2的記錄
//返回該記錄在主表中的下標位置,若查找失敗則返回-1
int i, j;
for (i = 0; i m; i++)
if (K1 == B[i].index)
break;
if (i == m)
return -1; //查找失敗
j = B[i].start;
while (j B[i].start + B[i].length)
{
if (K2 == A[j].key)
break;
else
j++;
}
if (j B[i].start + B[i].length)
return j; //查找成功
else
return -1; //查找失敗
}
顧名思義 是類似“目錄”的東西 在c語言中可能是數組, 每個元素都是對應的“結構體”(廣義)指針
能簡短的說明一下你想要什么么,我的理解是給我一個數組,讓我排序,最后輸出一個從小到大(或從大到小)的數組的原數組元素下表。
比如是s[10]={21,51,12,0,61,81,91,41,71,31} 排序后a[10]={0,12,21,31,41,51,61,71,81,91}
輸出為3,2,0,9,7,1,4,8,5,6對應0:s[3]=0,1:s[2]=12,2:s[0]=21,。。。。。。是這樣不?
用索引做排序就可以了
void select_sort(int *a, int len) {
int Min;
int *index;
index=(int *)new int[len];
for ( int i=0;ilen;i++ ) index[i]=i;
for (int i = 0; i len - 1; i++) {
for (int j = 1 + i; j len; j++) {
if (a[index[i]] a[index[j]]) {
Min=index[i];
index[i]=index[j];
index[j]=Min;
}
}
}
for ( int i=0;ilen;i++ ) coutindex[i]' '; coutendl;
for ( int i=0;ilen;i++ ) couta[index[i]]' '; coutendl;
delete [] index;
}
當前文章:c語言函數索引,c語言中索引
標題URL:http://m.newbst.com/article42/dssiihc.html
成都網站建設公司_創新互聯,為您提供電子商務、品牌網站建設、定制開發、品牌網站設計、網站營銷、虛擬主機
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯