emmm……今天就不说那么多废话了,不然感觉都没时间来敲代码了QAQ,直接贴代码片了;
(一)最后一个单词的长度;就是从最后一个字母数起,到遇到第一个空格时停止。
#include
#include
int main()
{
int i,count=0;
char s[10001];
gets(s);
for(i = strlen(s)-1;i > 0;i--)
{
if(s[i] != ' ')
count++;
if(count > 0)
if(s[i] == ' ')
break;
}
printf("%d\n",count);
return 0;
}
(二)整数转换成罗马数字;喵,小姐姐很无奈,不是很能理解罗马数字呀,这是借鉴的别人的555,不过思路很简单,就是穷举法,把它的所有值都列出来存数组里然后得出各个位置的数字之后从数组里找。
#include
int main()
{
char* c[4][10]={
{"","I","II","III","IV","V","VI","VII","VIII","IX"},
{"","X","XX","XXX","XL","L","LX","LXX","LXXX","XC"},
{"","C","CC","CCC","CD","D","DC","DCC","DCCC","CM"},
{"","M","MM","MMM"}
};
int n;
scanf("%d",&n);
printf("%s",c[3][n/1000]);
printf("%s",c[2][n%1000/100]);
printf("%s",c[1][n%100/10]);
printf("%s",c[0][n%10]);
return 0;
}
(三)罗马数字转整数;这个就简单很多了;因为它只有那几个字母,把输入的罗马字符存数组里,再用分支法去比较就OK啦。
#include
#include
int main()
{
int i,count=0;
char s[4000];
gets(s);
for(i=0;iswitch(s[i]){
case 'M':count+=1000;break;
case 'D':count+=500;break;
case 'C':if(s[i+1]=='D'||s[i+1]=='M')
count-=100;
else
count+=100;
break;
case 'L':count+=50;break;
case 'X':if(s[i+1]=='L'||s[i+1]=='C')
count-=10;
else
count+=10;
break;
case 'V':count+=5;break;
case 'I':if(s[i+1]=='V'||s[i+1]=='X')
count-=1;
else
count+=1;
break;
}
}
printf("%d\n",count);
return 0;
}
(四)单独的数字;用数组存储下每一个数字的出现次数,然后输出次数为一的就行了。
#include
int main()
{
int n,a[501];
scanf("%d",&n);
for(int i=0;i"%d",&a[i]);
}
for(int j=0;jint f=0;
for(int k=0;kif(a[j]==a[k])
f++;
}
if(f==1)
printf("%d",a[j]);
}
return 0;
}
(五)爬楼梯;跟上面的斐波那契数列是一样的,就是前面的两个数字改了下而已,所以提供另一种解法。
#include
int main()
{
int n,sum1=1,sum2=2,sum=0;
scanf("%d",&n);
if(n==1)
printf("1");
else if(n==2)
printf("2");
else {for(int i=3;i<=n;i++)
{
sum=sum1+sum2;
sum1=sum2;
sum2=sum;
}
printf("%d",sum);
}
return 0;
}
(六)x的平方根;还是很简单的一道水体=题啊,不过我猜它本来应该是要我写函数的,但谁叫我懒呢,就不写,就不写。
#include
#include
int main()
{
int n;
while(scanf("%d",&n)!=EOF){
printf("%d\n",(int)sqrt(n));
}
return 0;
}
(七)跳跃游戏;用贪心,算它从第一个起每次加最大距离能不能到达终点。
#include
int main()
{
int n,sum=0;
scanf("%d",&n);
int a[n];
for(int i=0;i"%d",&a[i]);
}
for(int i=0;isum+=a[sum];
if(sum>=n-1){
printf("true");break;}
else if(a[sum]==0){
printf("false");break;}
}
return 0;
}
(八)加一;还是用数组emmmm…..毕竟渣渣只一个数组用得还熟一点,从最后一个起,判断是否等于9,是的话就进一。
#include
int main()
{
int n,a[101];
scanf("%d",&n);
for(int i=0;i"%d",&a[i]);
}
int x=1;
for(int j=n-1;j>=0&&x==1;j--)
{
if(a[j]==9)
{
a[j]=0;
}
else
{
a[j]+=1;
x=0;
}
if(a[0]==0&&x==1)
{
printf("1 ");
}
}
for(int k=0;kprintf("%d ",a[k]);
}
return 0;
}
(九)跳跃游戏二;咩咩,这道题不会,是借鉴的别人的,5555,所以说我好水QAQ
#include
int n,s[10000]={0},ct=0;
int bfs(int i)
{
int k,j=0,l,max=0;
if(i>=n-1) return 0;
k=s[i];ct++;
if(i+k>=n-1) return 0;
for(l=i+1;l<=i+k;l++)
{
if(max<=l+s[l])
{
j=l;max=l+s[l];
}
}
bfs(j);
}
int main()
{
int i;
scanf("%d",&n);
for(i=0;i"%d",&s[i]);
}
bfs(0);
printf("%d",ct);
return 0;
}
(十)最大子阵列;考虑下它加的后一个数的正负问题,然后再判断那连续数列的和的正负,如果为负,那就可以直接跳到下一个值了。
#include
using namespace std;
int maxSum(int* a, int n)
{
int sum=a[0];
int b=0;
for(int i=0; iif(b<0)
b=a[i];
else
b+=a[i];
if(sumreturn sum;
}
int main()
{
int n;
cin>>n;
int a[n];
for(int i=0;icin>>a[i];
}
cout<return 0;
}
啦啦啦~成功完成第二篇。