請(qǐng)編寫(xiě)函數(shù)fun,函數(shù)的功能是: 移動(dòng)字符串中的內(nèi)容,移動(dòng)的規(guī)則如下: 把第1到第m個(gè)字符, 平移到字符串的最后, 把第m+1到最后的字符移到字符串的前部。
例如, 字符串中原有的內(nèi)容為: ABCDEFGHIJK, m的值為3, 則移動(dòng)后, 字符串中的內(nèi)容應(yīng)該是: DEFGHIJKABC。
注意:部分源程序在文件PROG1.C中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容, 僅在函數(shù)fun的花括號(hào)中填入你編寫(xiě)的若干語(yǔ)句。
給定源程序:
#include
#include
#define N 80
void fun1(char *w) /* 本函數(shù)的功能是將字符串中字符循環(huán)左移一個(gè)位置 */
{
int i; char t;
t=w[0];
for(i=0;i w[i]=w[i+1];
w[strlen(w)-1]=t;
}
void fun(char *w, int m) /* 可調(diào)用fun1函數(shù)左移字符 */
{
}
main()
{ char a[N]= "ABCDEFGHIJK";
int m;
printf("The original string:\n");puts(a);
printf("\n\nEnter m: ");scanf("%d",&m);
fun(a,m);
printf("\nThe string after moving:\n");puts(a);
printf("\n\n");
NONO();
}
解題思路:
本題是考察字符串的操作。
1. 由于函數(shù)fun1是將字符串中字符循環(huán)左移一個(gè)位置,并通過(guò)實(shí)參w返回循環(huán)左移一個(gè)位置的字符串。
2. 利用循環(huán)for語(yǔ)句來(lái)操作多少個(gè)字符(m)需要循環(huán)左移。
參考答案:
void fun1(char *w) /* 本函數(shù)的功能是將字符串中字符循環(huán)左移一個(gè)位置 */
{
int i; char t;
t=w[0];
for(i=0;i w[i]=w[i+1];
w[strlen(w)-1]=t;
}
void fun(char *w, int m) /* 可調(diào)用fun1函數(shù)左移字符 */
{
int i;
for(i = 0 ; i < m ; i++) fun1(w);
}
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |