我决定改编你的display: table-cell版本。
最重要的变化是添加table-layout: fixed. 这样做是在没有指定的列之间平均分配剩余的可用宽度width。
见:http:  //jsfiddle.net/thirtydot/5p5V9/2/
CSS:
.outer {
    color: #ffffff;
    background-color: #373737;
}
.inner {
    display: table;
    table-layout: fixed;
    width: 100%;
}
.inner > div {
    display: table-cell;
}
.alignC {
    text-align: center;
    font-weight: bold;
    color: #949494;
    background-color: #2e2e2e;
}
.first, .alignC {
    width: 46px;
    font-weight: bold;
}
.alignR, .alignL {
    background: #666;
}
HTML:
<div class="outer">
    <div class="inner">
        <div class="first">1</div>
        <div class="alignR">r</div>
        <div class="alignC">m</div>
        <div class="alignL">This long text shall break in the div</div>
    </div>
</div>
浏览器支持display: table-cell.